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。 在 XAMPP 集 成 环境 下 ， 使 用 Dreamweaver 
软件 可 视 化 对 PHP 动 态 网 站 的 开发 ， 适 合 初 
学 者 学 习 使 用 。 

。8 个 完整 的 项 目 开发 实例 ， 从 可 视 化 操作 到 
手写 代码 的 过 程 进行 设计 ， 掌 握 常用 电子 商 
务 网 站 的 各 模块 功能 开发 。 

。 全 书 代 码 可 以 从 网 上 下 载 ， 完善 的 B2C 型 电 
子 商务 购物 车 功能 系统 ， 适 合 企业 应 用 和 相 
关 专 业 学 生 的 毕业 设计 应 用 。 
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一 


前 言 


PHP 是 一 种 执行 于 服务 器 端 、 幅 入 HTML 文 档 的 脚本 语言 ， 语 言 风 格 类 似 于 C 语 
言 。 MySQL 是 一 种 关联 数据 库 管理 系统 ， 其 体积 小 、 速 度 快 、 总 体 拥有 成 本 低 、 开 放 源 
人 码 。MySQL 搭 配 PHP 和 Apache 可 组 成 良好 的 开发 环境 ,该 技术 已 成 为 目前 国内 中 小 型 网 站 
普遍 采用 的 网 站 开发 方式 。 

本 书 共 分 10 章 , 前 2 章 介绍 网 站 开发 环境 的 配置 及 PHP 的 基本 语法 规范 ， 后 8 章 分 别 为 8 
个 完整 的 网 站 开发 全 程 实例 ， 读 者 可 根据 自己 的 需要 打 乱 顺序 学 习 ， 借 览 这 些 项 目 。 各 章 
节 的 内 容 如 下 : 

第 1 章 引 导读 者 进入 PHP 开 发 领域 ， 了 解 Web 开 发 所 需要 的 各 种 构件 ， 掌 握 基于 数据 库 
的 动态 网 站 运行 原理 ， 以 及 PHP 的 功能 、 开 发 优势 和 发 展 趋势 。 在 Windows 系 统 下 独立 安 
装 各 种 PHP 所 需要 的 开发 环境 ， 掌 握 MySQL 数 据 库 的 管理 方法 。 

第 2 章 以 小 实例 的 形式 着 重 介绍 了 PHP 的 基本 语法 ， 包 括 语言 风格 、 数 据 类 型 、 变 量 、 
常量 、PHP 运 算 符 和 表达 式 的 内 容 还 介绍 了 PHP 的 语言 结构 ， 包 括 条 件 语句 、 循 环 语句 
等 流程 控制 结构 和 函数 声明 与 应 用 的 各 个 环节 ; 介绍 了 PHP 的 数组 与 数据 结构 的 应 用 。 

第 3 童 介绍 了 全 程 实例 : 成 绩 查询 系统 。 重点 介绍 了 Dreamweaver 进 行 PHP 开 发 的 流程 ， 
搭建 PHP 动 态 系统 开发 的 平台 ， 检 查 数据 库 记 录 的 常见 操作 和 编辑 记录 的 常见 操作 。 

第 4 章 介绍 了 全 程 实例 : 用 户 管理 系统 。 本 书 按照 软件 开发 的 基本 过 程 ， 以 系统 的 需 
求 分 析 、 数 据 库 设 计 和 系统 的 设计 为 基本 开发 步 又， 详细 介绍 了 用 户 管理 系统 开发 的 全 前 
过 程 。 通 过 对 用 户 注册 信息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ， 通 过 对 用 户 权 
限 的 设置 ， 可 以 限制 其 对 网 站 页 面 的 访问 。 

第 5 章 介绍 了 全 程 实例 : 新 闻 管 理 系统 。 新 闻 管 理 系统 主要 实现 对 新 闻 的 分 类 和 发 布 ， 
本 实例 模拟 了 一 般 新 闻 媒 介 的 发 布 过 程 。 新 闻 管理 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 
对 新 闻 的 不 断 更 新 , 使 用 户 能 及 时 了 解 行业 信息 、 企业 状况 以 及 其 他 需要 了 解 的 知识 。 PHP 
实现 这 些 功能 相对 比较 简单 ， 涉 及 的 主要 操作 有 访问 者 的 新 闻 查 询 功 能 ， 系 统管 理 员 对 新 
闻 的 新 增 、 修 改 和 删除 功能 。 

第 6 章 介绍 了 全 程 实例 : 在 线 投票 管理 系统 。 一 个 投票 管理 系统 可 分 为 3 个 主要 的 功能 
模块 : 投票 功能 、 投票 处 理 功能 以 及 显示 投票 结果 功能 。 投票 管理 系统 首先 给 出 投票 选 题 ， 
即 供 投票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 投 票 处 理 功能 激活 ， 对 服务 
器 传送 过 来 的 数据 做 出 相应 的 处 理 , 先 判断 用 户 选择 的 是 哪 一 项 , 并 累计 相应 项 的 字段 值 ， 
然后 对 数据 库 进 行 更 新 ， 最 后 将 投票 的 结果 显示 出 来 。 

第 7 章 介绍 了 全 程 实例 : 留言 每 管理 系统 。 网 站 留言 板 管理 系统 的 功能 主要 是 实现 网 
站 的 访问 者 和 网 站 管理 者 的 一 个 交互 性 ， 访 问 者 可 以 向 管理 者 提出 任何 意见 和 信息 ， 管 理 
者 可 以 在 后 台 及 时 回复 。 开 发 的 技术 主要 涉及 数据 库 留 言 信 息 的 插入 ， 回 复 和 修改 信息 的 


更 新 等 操作 ， 在 设计 回复 时 还 会 涉及 一 些 关 于 PHP 时 间 函 数 的 设置 问题 。 

第 8 章 介绍 了 全 程 实例 : 网 站 论坛 管理 系统 。 论 坛 管理 系统 的 主要 功能 是 通过 在 计算 
机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 通 过 Internet 来 进行 连接 ， 执 行 用 户 消息 之 间 
的 交互 功能 。 支 持 用 户 建 贴 、 回 复 、 搜 索 、 查 看 等 功能 。 主 要 设计 网 站 论坛 管理 系统 的 首 
页 ， 用 户 可 以 在 这 里 发 布 讨论 的 主题 ， 也 可 以 回复 主题 ， 并 且 版 主 可 以 对 自己 的 栏目 或 版 
块 进行 删除 、 修 改 等 操作 。 

第 9 章 重 点 介绍 了 全 程 实例 : 莫 众 电子 商城 前 台 。 网 上 购物 系统 通常 拥有 产品 发 布 、 
订单 处 理 和 购物 车 等 动态 功能 ,管理 者 登录 后 台 管 理 , 即 可 进行 商品 维护 和 订单 处 理 操 作 。 
网 络 商店 是 比较 庞大 的 系统 ， 它 必须 拥有 会 员 系 统 、 查 询 系统 、 购 物流 程 和 会 员 服 务 等 功 
能 模块 ， 这 些 功 能 模块 通过 用 户 身份 的 验证 统一 进行 使 用 ， 从 技术 角度 上 分 析 难 点 就 在 于 
数据 库 中 各 系统 数据 表 的 关联 。 本 实例 介绍 了 使 用 PHP 进 行 网 上 购物 系统 前 台 开 发 的 方法 ， 
系统 介绍 了 莫 俯 电子 商城 的 前 台 设 计 、 数 据 库 的 规划 以 及 常用 的 几 个 前 台 功 能 模块 的 开 
发 。 

第 10 章 介绍 了 全 程 实例 : 翡 芙 电子 商城 后 台 。 翡 尉 电子 商城 前 台 主 要 实现 了 网 站 针对 
会 员 的 所 有 功能 ， 包 括 了 会 员 注 册 ， 购 物 车 以 及 回复 留言 功能 的 开发 。 但 一 个 完善 的 网 上 
购物 系统 并 不 只 提供 给 用 户 注册 ， 还 要 给 网 站 所 有 者 一 个 功能 齐全 的 后 台 管 理 功 能 。 网 站 
所 有 者 登录 后 台 管 理 即 可 进行 发 布 新 闻 公 告 、 会 员 注册 信息 的 管理 、 回 复 留言 、 商 品 维护 
以 及 进行 订单 的 处 理 等 等 。 

本 书 是 针对 PHP 开 发 初级 读者 特别 编写 的 图 书 ， 书 中 使 用 的 Dreamweaver CC 是 最 新 版 
本 ， 书 中 应 用 到 了 Dreamweaver CC 的 扩展 应 用 如 “服务 器 行为 ”面板 的 绑 定 ， 可 以 方便 初 
学 者 快速 实现 PHP 的 动态 功能 开发 ， 读 者 在 下 载 Dreamweaver CC 版 本 后 需要 安装 Adobe 
Extension Manage CC， 然 后 下 载 Deprecated_ServerBehaviorsPanel_ Support.zxp 扩 展 安装 即 
可 以 完全 使 用 。 

本 书 由 于 荷 云 编著 ， 此 外 ， 陈 益 材 、 韩 美 坤 、 姜 海洋 、 施 慧 、 王 峰 、 王 要 楠 、 王 玉 州 、 
于 清 勇 、 张 波 、 朱 文 军 、 邹 亮 等 参与 了 部 分 章节 的 编写 工作 ， 他 们 均 为 常年 从 事 商 业 网 站 
建设 的 资深 网 页 设计 师 。 由 于 作者 水 平 有 限 ， 书 中 玻 漏 之 处 在 所 难免 ， 恳 请 专家 和 广大 读 
者 批评 指正 。 在 学 习 过 程 中 如 果 遇 到 疑难 问题 ， 可 以 通过 以 下 方式 与 我 们 联系 : 
booksaga@126.com， 也 可 以 访问 图 格 新 知 官方 微 博 http://weibo.com/booksaga 留 言 ， 我 们 将 
在 第 一 时 间 给 予 答复 ! 


本 书 实例 项 目 代 码 可 以 从 下 面 网 址 下 载 ， 如 果 下 载 有 问题 可 发 电子 邮件 索取 ， 邮 件 主 


题 为 “ 求 PHP+MySQL 一 书 代码 ”。 
下 载 网 址 : http:/pan.baidu.com/s/1qWHTCte 


编 者 
2015 年 12 月 
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第 章 


PHP 网 站 开发 环境 的 配置 


PHP 是 一 种 多 用 途 脚 本 语言 ,尤其 适合 于 Web 应 用 程序 开发 。 使 用 PHP 强 大 的 扩展 性 ， 
可 以 在 服务 端 连接 Java 应 用 程序 ， 还 可 以 与 .NET 建 立 有 效 的 沟通 甚至 更 广阔 的 扩展 ， 从 
而 可 以 建立 一 个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 资源 。 并 且 ， 开源 和 跨 
平台 的 特性 使 得 使 用 PHP 架 构 能 够 快速 、 高 效 地 开发 出 可 移植 的 、 跨 平台 的 、 具 有 强大 功 
能 的 企业 级 Web 应 用 程序 。 在 使 用 PHP 进 行 网 站 开发 之 前 ， 需 要 在 操作 系统 上 搭建 一 个 
适合 PHP 开 发 的 操作 平台 .使 用 Windows 自 带 的 l1S 服 务 器 或 者 单独 安装 一 个 Apache 服 务 
器 都 可 以 实现 PHP 的 解析 运行 ， 对 于 刚 入 门 的 新 手 而 言 ， PHP 的 开发 环境 推荐 使 用 
Apache ( 服务 器 ) + Dreamweaver ( 网 页 开发 软件 ) +MySQL ( 数据 库 ) 组 合 ， 本 章 
将 重点 介绍 PHP 网 站 开发 环境 的 配置 。 对 于 初学 者 建议 直接 安装 XAMPP 集 成 环境 进行 学 
习 。 


本 章 的 学 习 重 点 

@ PHP 5.0 的 基础 知识 
Apache 服 务 器 的 安装 与 配置 
PHP 环 境 的 安装 与 配置 
MySQL 数 据 库 的 安装 
phpMyAdmin 的 配置 和 使 用 
XAMPP 安 装 和 使 用 


:Sle 网 站 开发 全 程 实例 〈 第 2 版 ? 
SS @iDs 


11.1 PHP 5.0 开 发 环境 与 特性 


PHP 全 名 为 Personal Home Page， 是 最 普及 、 应 用 最 广泛 的 Web 开 发 语言 之 一 ， 其 语 
法 混合 了 C、Java、Perl 以 及 PHP 自 创新 的 语法 。 它 具有 开放 的 源 代码 ， 多 种 数据 库 的 支持 ， 
并 且 支 持 跨 平台 的 操作 和 面向 对 象 的 编程 ， 而 且 有 完全 免费 的 特点 。 本 小 节 首 先 介 绍 一 下 
最 新 版 本 PHP 5.0 的 一 些 新 特点 和 开发 环境 的 搭建 知识 。 


-TTT 开发 环境 的 配置 步 也 


PHP 的 运行 环境 需要 两 个 软件 的 支持 : 一 个 是 PHP 运 行 的 Web 服 务 器 Apache， 而 在 具 
体 安装 Apache 服 务 器 之 前 首先 又 要 在 运行 的 系统 上 安装 支持 Apache 服 务 器 的 Java 2 SDK; 
一 个 是 PHP 运 行 时 需要 加 载 的 主要 软件 包 , 该 软件 包 主 要 是 解释 执行 PHP 页 面 的 脚本 程序 ， 
如 解释 PHP 页 面 的 函数 。 本 书 主要 介绍 Windows 操 作 系统 下 使 用 Apache+PHP 配 置 环 境 的 方 
法 。 

PHP 开 发 运行 环境 的 需求 如 图 1-1 所 示 : 


第 一 步 安装 Apache 服务 器 Apas88 


第 二 步 : 安装 配置 PHP 


第 三 步 : 安装 配置 MySQL 数据 库 


第 四 步 : 安装 PhpMyAdmin 管 理 数据 库 
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图 1-1 PHP 环境 配置 步骤 


-LTD )PHP 5.0 的 新 特性 


PHP 是 超 文 本 预 处 理 语言 (PHP:Hypertext Preprocessor) 的 嵌 套 缩写 ， 是 一 种 HTML 
内 藤 式 的 语言 。 与 微软 的 ASP 相 似 ， 都 是 一 种 在 服务 器 端 执行 、 骨 入 HTML 文 档 的 脚本 语 
言 ， 语 言 的 风格 又 类 似 于 C 语 言 ， 现 在 被 很 多 的 网 站 编程 人 员 接 纳 采 用 。 

用 PHP 做 出 的 动态 页 面 与 其 他 的 编程 语言 相 比 ，PHP 是 将 程序 嵌入 到 HTML 文 档 中 去 
执行 ， 执 行 效率 比 完全 生成 HTML 标 记 的 CGI 要 高 许多 ; 与 同样 是 嵌入 HTML 文 档 的 脚本 
语言 JavaScript 相 比 ，PHP 在 服务 器 端 执 行 ， 充 分 利用 了 服务 器 的 性 能 ，PHP 执 行 引擎 还 会 
将 用 户 经 常 访问 的 PHP 程 序 驻 留 在 内 存 中 ， 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 
编译 程序 ， 只 要 直接 执行 内 存 中 的 代码 就 可 以 ， 这 也 是 PHP 高 效率 的 体现 之 一 ， 如 图 1-2 
所 示 为 PHP 的 运行 模式 。 PHP 还 具有 非常 强大 的 功能 , 所 有 的 CGI 或 者 JavaScript 的 功能 PHP 


三 三 < 


都 能 实现 ， 而 且 支持 几乎 所 有 流行 的 数据 库 以 及 操作 系统 。 


包 名 名 
OU 


Apache 服务 器 MySQL 数据 库 
图 1-2 PHP 网 站 的 运行 模式 

PHP 最 初 只 是 简单 地 用 Perl 语 言 编写 的 程序 ， 用 来 统计 自己 网 站 的 访问 量 。 后 来 又 用 C 
语言 重新 编写 ， 包 括 可 以 访问 数据 库 等 功能 ， 并 在 1995 年 发 布 了 PHP 1.0。2004 年 7 月 13 日 
PHP 5.0 正 式 版 本 的 发 布 , 标志 着 一 个 全 新 的 PHP 时 代 的 到 来 . 它 的 核心 是 第 二 代 Zend 引 擎 ， 
并 引入 了 对 全 新 的 PECL 模 块 的 支持 。 在 不 断 更 新 的 同时 ，PHP 5.0 依 然 保 留 对 旧 PHP 4.0 
程序 的 兼容 。 随 着 MySQL 数 据 库 的 发 展 ，PHP 5.0 还 绑 定 了 新 的 MySQLi 扩 展 模 块 ， 提 供 了 
一 些 更 加 有 效 的 方法 和 实用 工具 用 于 处 理 数据 库 操作 。PHP 5.0 添 加 了 面向 对 象 的 PDO 
《PHP Data Objects) 模块 ， 提 供 了 另外 一 种 数据 库 操作 的 方案 ， 统 一 数据 库 操 作 的 API。 
另外 ，PHP 5.0 中 还 改进 了 创建 动态 图 片 的 功能 ， 目 前 能 够 支持 多 种 图 片 格式 (如 PNG、 
GIF、TTIF、JPEG 等 ) 。PHP 5.0 已 经 内 置 了 对 GD2 库 的 支持 ， 因 此 安装 GD2 库 (主要 指 
UNIX 系 统 中 ) 也 不 再 是 件 难事 ， 这 使 得 处 理 图 像 变 得 十 分 简单 和 高 效 。 

PHP 5.0 还 增加 了 只 有 成 熟 的 编程 语言 体系 结构 中 才 有 的 一 些 特性 , 如 下 面 列 出 的 这 些 


(1) 增加 的 面向 对 象 能 力 

PHP 5.0 的 最 大 特点 是 引入 了 面向 对 象 的 全 部 机 制 ,并 且 保 留 了 向 下 的 兼容 性 。 程序 员 
不 必 再 编写 缺乏 功能 性 的 类 ， 并 且 能 够 以 多 种 方法 实现 类 的 保护 。 另 外 ， 在 对 象 的 集成 等 
方面 也 不 再 存在 问题 。 使 用 PHP 5.0 引 进 的 类 型 提示 和 异常 处 理 机 制 , 能 更 有 效 地 处 理 和 避 
免 错误 的 发 生 。PHP 5.0 增 加 了 很 多 功能 ， 例 如 显 式 构造 函数 和 析 构 函数 、 对 象 克隆 、 类 抽 
象 、 变 量 作 用 域 和 接口 等 。 


(2) try/catch 异 常 处 理 

从 PHP 5.0 开 始 支持 异常 处 理 。 在 许多 语言 中 ， 如 C++、C#、Python 和 Java 等 ， 异 常 处 
理 长 期 以 来 一 直 都 是 错误 管理 方面 的 中 流 丰 柱 ， 为 建立 标准 化 的 错误 报告 逻辑 提供 了 一 种 
绝 佳 的 方法 。 

(3) 字符 串 处 理 

之 前 版 本 的 PHP 默 认 将 字符 串 看 作 数 组 ， 这 也 反映 了 PHP 原 先 的 数据 类 型 观点 不 够 严 
密 。 这 种 策略 在 版 本 5.0 中 有 所 调整 ， 引 入 了 一 种 专门 的 字符 串 偏 移 量 (offset) 语法 ， 而 
以 前 的 方法 已 经 废弃 不 用 。 


(4) XML 和 Web 服 务 支持 
现在 的 XML 支持 建立 在 libxml2 库 基础 上 , 并 引入 一 个 很 新 并 且 非 常 有 前 途 的 扩展 包 来 
解析 和 处 理 XML: SimpleXML 。 此 外 ，PHP 5.0 还 支持 SOAP 扩 展 。 


(5) 对 SQLite 的 内 置 支持 

PHP 5.0 为 功能 强大 、 简 洁 的 SQLite 数 据 库 服务 器 提供 了 支持 。 如 果 开 发 人 员 需 要 使 用 
一 些 只 有 重量 级 数据 库 产品 中 才 有 的 特性 ， 同 时 不 希望 带 来 相应 的 管理 开销 ，SQLite 则 是 
一 个 很 好 的 解决 方案 。 


1 1.2 Apache 服务 器 的 安装 与 操作 


基于 Windows 操 作 系 统 支持 PHP 开 发 的 服务 器 主要 有 IIS 和 Apache 两 款 ， 其 中 Apache 服 
务 器 是 专门 为 PHP 设 置 的 解析 服务 器 ， 本 小 节 重 点 介绍 Apache 服 务 器 的 安装 和 设置 。 
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自从 PHP 发 布 之 后 ， 推 出 了 各 式 各 样 的 PHP 引 擎 ， 最 为 经 典 的 配置 就 是 使 用 Apache 服 
务 器 。Apache 是 一 种 开源 的 HTTP 服 务 器 软件 ， 可 以 在 包括 UNIX、Linux 以 及 Windows 在 内 
的 大 多 数 主流 计算 机 操作 系统 中 运行 ， 由 于 其 支持 多 平台 和 良好 的 安全 性 而 被 广泛 使 用 。 
Apache 作 为 常 驻 的 后 台 任 务 运 行 。 在 UNIX 系 统 中 为 守候 进程 (Daemon) ， 在 Windows 
系统 中 为 服务 (Service》。 由 于 Apache 服 务 器 的 启动 阶段 比较 耗费 时 间 和 资源 ， 因 此 它 一 
般 在 操作 系统 启动 时 被 启动 并 一 直 运 行 。 

Apache 的 运行 分 为 启动 阶段 和 运行 阶段 。 启 动 阶段 时 ，Apache 以 特权 用 户 root 启 动 ， 
进行 解析 配置 文件 、 加 载 模 块 和 初始 化 一 些 系统 资源 (例如 日 志文 件 、 共 享 内 存 段 、 数 据 
库 连接 ) 等 操作 。 处 于 运行 阶段 时 ，Apache 放弃 特权 用 户 级 别 ， 使 用 非特 权 用 户 来 接收 
和 处 理 网 络 中 用 户 的 服务 请 求 。 这 种 基本 安全 机 制 可 以 阻止 Apache 中 由 于 一 个 简单 软件 
错误 (也 可 能 是 模块 或 脚本 ) 而 导致 的 严重 系统 安全 漏洞 ， 例 如 微软 的 IIS 就 曾 遭 受 “ 红 色 
代码 (Code Red) ”和 “ 尼 姆 达 (Nimda) ”等 恶意 代码 的 溢出 攻击 。 

Apache 的 主 配置 文件 通常 为 httpd.conf。 但 是 由 于 这 种 命名 方式 为 一 般 惯例 ， 并 非 强 制 
要 求 , 因此 提供 mpm 或 者 deb 包 的 第 三 方 , Apache 发 行 版 本 可 能 使 用 不 同 的 命名 机 制 。 另 外 ， 
httpd.conf 文 件 可 能 是 单一 文件 , 也 可 能 是 通过 使 用 Include 指 令 包 含 不 同 配置 文件 的 多 个 文 
件 集合 。 有 些 发 行 版 本 的 配置 非常 复杂 。httpd.conf 文件 是 一 个 文本 文件 ， 在 系统 启动 时 
被 逐 行 解析 。 该 文件 由 指令 、 容 器 和 注释 组 成 。 配 置 文件 内 允许 有 空 行 和 空格 ， 它 们 在 解 
析 时 被 忽略 不 计 。 


Apache 服 务 器 的 下 载 
Apache 软 件 和 其 他 免费 软件 一 样 ， 可 以 直接 到 Apache 的 官方 网 站 进行 下 载 ， 下 载 的 地 
址 是 : http:/httpd.apache.org/download.cgi。 下 载 Apache 的 最 新 版 本 步骤 如 下 : 
打开 IE 浏览 器 ， 在 网 址 列 输入 http:Whttpd.apache.org/download.cgi 链 接 至 Apache 的 
官方 网 站 ， 如 图 1-3 所 示 。 
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图 1-3 打开 的 官方 网 站 


园 在 这 个 页 面 中 有 许多 的 下 载 选 项 ， 为 了 初学 者 安装 的 容易 ， 下 载 Apache 的 自动 安 


装 程序 ， 单 击 选择 页 面 上 的 “httpd-2.0.65-win32-x86-no_ssl.msi” 


文字 ， 如 图 1-4 所 示 。 
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图 1-4 选择 相应 的 文件 下 载 


本 书 所 下 载 的 是 编写 此 书 时 的 最 新 版 本 ， 由 于 Apache 软 件 经 常 更 新 版 本 ， 读 者 可 能 会 下 载 到 不 


同 的 最 新 版 本 ， 但 这 不 会 影响 后 面 的 操作 与 设置 。 
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完成 下 载 Apache 的 安装 程序 后 ， 双 击 下 载 的 可 执行 安装 文件 (在 本 书 的 原 素材 资源 中 


phpsoft 文 件 夹 下 也 有 下 载 的 安装 文件 包 ) ， 如 图 1-5 所 示 。 


有 


J 站 


le 网 站 开发 全 程 实例 (第 2 版 ) 
SS @ce 


图 1-5 下 载 的 Apache 安装 文件 包 


安装 的 步骤 如 下 : 


加 双击 安装 文件 包 ， 


Apache 安 装 精灵 会 提示 我 们 将 安装 Apache 服 务 器 ， 并 有 警告 信 
息 ， 如 图 1-6 所 示 。 


上 二 
划 Apache HTTP Server 2.0 ~ Installation Wizard [| 


Welcome to the Instaliation Wizard for 
Apache HTTP Server 2.0.65 


The Instalation Wizard wil insial Apache HTTP Server 2.0.65 
on your computer, To continue, chck Next, 


WARNING: This progran is pretected by cepyright law and 
ntermatona veases. 


er) re] 
图 1-6 开始 安装 


四 单 击 Next > |」 按钮 ， 继 续 安装 程序 。 选 中 “I accept the terms in the license 


agreement ( 我 接受 告知 条 款 上 的 内 容 ) ” 单 选 按钮 同意 合约 的 授权 ， 继 续 进行 安装 ， 如 图 
1-7 所 示 。 


区 Apache HTTP Server 2.0 - Installation Wizard 


License Aareement 
Piease read the folowng lcense agreementcarefuly 
Apache License 
Version 2.0, Janvary 2004 
httpsIvww.apache.org/licenses/ 


[TERMS AND CONDMTIONS FOR UsE REPRODUCTION, AND DISTRIBUTION 
|1. Definitions. 


“License” shall mean the terms and conditions for use. reproduction, and 
distribulion as defined by Secions 1 through 9 cfthis document 
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图 1-7 同意 安装 


人 


加 单 击 [ Nex> 按钮 ， 继 续 安 装 程序 ， 打 开 “Read This First ( 预 读 下 面 内 容 ) ” 界 
面 ， 如 图 1-8 所 示 。 


划 Apache HTTP Server 20 - Installation Wizard 区 二 | 


Read This First 
Read this Before Running Apache on Windows. 


Apache HTTP Server 


IWhatis it? 

|The Apache HTTP Server is a powerful and flexible HTTP/1.1 compliant web server. 

Originally designed as a replacement for the NCSA HTTP Server, thas grown to be 
ie most popular web server on the Intemet. As a project of the Apache Software 

Foundation, the developers aim to collaboratively develop and maintain a robust 

commercial-grade, standards-based server with freely available source code. 


Ihe Latest Version 
Details ofthe latest version can be found on the Apache HTTP server project page 
under 


httpJhttpdapache orgl 
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图 1-8 “Read This First ( 预 读 下 面 内 容 ) ”界面 


加 在 预 读 界 面 中 主要 是 介绍 Apache HTTP Server (Apache 网 页 服务 器 ) 的 一 些 基础 
知识 , 初次 使 用 的 读者 可 以 认真 地 去 了 解 一 下 , 以 方便 进一步 地 使 用 。 单 击 [Next> | 按钮 ， 
打开 “Server Information (服务 器 信息 ) ”界面 ， 如 图 1-9 所 示 。 这 里 要 自行 设 定 服务 器 和 
域名 名 称 ， 并 要 输入 管理 者 的 联系 邮箱 。 


(WM Apache HTTP Sever 20 - Installation Wizard 区 本 


Network Domain (e.g. somenet.com) 
[phpserver 
| Server Name (e.g. www.somenet.com): 


per 


Administrator's Email Address (e.g. webmaster @somenet.com): 
sssol3aeqq.com 


Install Apache HTTP Server 2.0 programs and shortcuts for: 


® for Al Users, on Port 80, as 3 Service Recommended. 
© only for the Current User, on Port 8080, when started Manualy. 
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Server Information 
Please enter your server's information 
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图 1-9 “Server Information (服务 器 信息 ) ”对 话 框 


加 设 定 完 成 后 ， 再 单 击 [_ Next > | 按钮 ， 继 续 进 行 下 一 步 的 安装 。 打 开 “Setup Type 
(安装 类 型 ) ”界面 ， 这 里 有 Typical ( 典型 ) 和 Custom ( 自 定义 ) 安装 两 个 单 选项 ， 如 图 


Pesane je (第 2 版 ) 
名 ‘Se 


划 Apache HTTP Server 2.0 - Installation Wizard 


Setup Type 
Choose the setup type that best suits your needs. 


Please select a setup type. 


© Typical 
Typical program features wl be instaled. (Headers and Libraries 
for compiing modules wil not be instaled.) 


S Custom 
Choose which program features you want installed and where they 
wil be installed. Recommended for advanced users. 


Installshield 一 


图 1-10 “Setup Type (安装 类 型 ) ”界面 
国 选中 “Custom( 自 定义 )” 单 选 按钮 , 再 单 击 | Next> 过 钮 , 打开 “Custom Setup 
( 自 定义 安装 内 容 ) ”界面 ， 如 图 1-11 所 示 。 这 里 将 选择 所 有 的 内 容 进行 安装 以 方便 
后 面 PHP 程 序 的 开发 应 用 的 需要 ， 由 于 Apache 预 设 的 路 径 有 点 长 ， 为 了 方便 起 见 ， 因 
此 将 安装 路 径 改 成 C:\Apache， 单 击 “Change (改变 ) ”按钮 ， 将 服务 器 的 安装 路 径 设 


置 为 C:\Apache\。 


期 Apache HTTP Server 2.0 - Installation Wizard 


Custom Setup 
Select the program features you want instaled. 


ee 


This feature requires OKB on 
Your hard drive. Ithas 2of 2 
Subfeatures selected. 
subfeatures require 35MB on 
your hard drive. 

JInstal to: 

coo 


[ rep |]( spae |[ ck | Nex> [ca | 
图 1-11 “Custom Setup ( 自 定义 安装 内 容 ) ”界面 


单 击 [ Next> | 按钮 ， 打开“Ready to Install the Program (准备 安装 ) ”界面 ， 如 
图 1-12 所 示 。 


草 Apache HTTP Server 2.0 - Installation Wizard [E> 
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图 1-12 准备 安装 对 话 框 
国 单 二 CBJ 按钮， 开始 进行 具体 的 安装 ， 安 装 的 过 程 如 图 1-13 所 示 。 
其 Apache HTTP Server 2.0 - Installation Wizard Ca 
Installing Apache HTTP Server 2.0.65 
The program features you selected are beng nstaled. ”4 


国 piease wait whie the Installation Wizard nstals Apache HTTP Server 
2.0,65. This may take several minutes. 


Status: 
Copyng new fles 
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图 1-13 安装 过 程 
国 安装 完成 后 ， 单 击 [Ensh_ 按钮 ， 如 图 1-14 所 示 。 


其 Apache HTTP Server 20 - Installation Wizard 区 本 | 


Installation Wizard Completed 


The Instalation Wizard has successfuly instaled Apache HTTP 
Server 2.0.65. CRdk Finish to eit the wizard. 


Cam) 


图 1-14 ”完成 安装 
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到 此 Apache 服 务 器 的 安装 步骤 就 完成 了 。 这 里 在 完 装 的 时 候 要 注意 使 用 的 操作 系统 端 
口 80 不 能 被 占用 ,如果 计 算 机 上 默认 安装 了 HS 并 已 经 占用 了 80 端 口 ,那么 需要 将 其 禁用 方 
可 安装 成 功 。 
-和 124 )Apache 服 务 器 的 操作 


安装 Apache 服 务 器 完成 后 ， 首 先 要 测试 一 下 前 面 的 安装 与 设 定 是 否 成 功 ， 由 于 我 们 是 
在 本 地 计算 机 安装 Apache 服 务 器 的 ， 因 此 它 的 HTTP 地 址 的 预 设 路 径 是 http:Wlocalhost。 

首先 请 打开 正 浏 览 器 ， 在 地 址 栏 输 入 http:Wlocalhost， 如 果 能 顺利 开启 如 图 1-1$ 所 示 的 
网 页 画面 ， 就 表示 Apache 服 务 器 服务 成 功 启 动 了 。 


由 个 在， 民明 esdhe et aerrer 已 经 守土 可 以 在 也 个 上 录 中 从 加 志 罕 ， 基 天 字 个 页 面 符 扫 -… 


这 不 是 你 想 看 见 的 页 面 吧 ? 


Andhe 广 氏 已经 上 在 此 划 行 大 中 
人 可 以 在 用 sw 的 网站 和 苇 上 ， 自 在 二 下面 的 和 片 -呈现 ore 


i Ac 


图 1-15 测试 成 功 页 面 
Apache 服 务 器 的 服务 ， 对 PHP 网 页 的 执行 有 很 重要 的 关联 ， 因 此 接着 我 们 要 来 说 明 
Apache 服 务 器 的 设 定 与 操作 。 


1. Apache 服务 器 的 启动 

当 在 Apache 服 务 器 安装 完成 的 页 面 上 ， 已 经 勾 选 “for All User,on Port 80,as a 
Service-Recommended.” 的 选项 ， 那 么 Apache 就 已 经 自动 启动 。 可 以 发 现在 Windows 工 作 
列 上 的 系统 图 标 多 了 一 个 贺 图 示 。 

如 果 Apache 服 务 器 停止 服务 后 要 再 启动 Apache 服 务 器 ， 请 在 Windows 系 统 图 标 中 的 加 
图 标 上 单 击 鼠标 右键 弹出 快捷 菜单 ， 再 选择 “Start (开始 ) ”选项 就 可 以 重新 启动 Apache 
服务 器 。 


2. Apache 服务 器 的 停止 

如 果 要 停止 Apache 服 务 器 , 请 在 Windows 系 统 图 标 中 的 轿 图 标 
上 单 击 鼠 标 右键 弹出 快捷 菜单 ， 只 要 选择 “Stop (停止 ”选项 就 
可 以 停止 Apache 服 务 器 的 服务 ， 如 图 1-16 所 示 ; 这 时 ，Apache 的 系 。 图 1-16 ”停止 操作 界面 
统 图 标 变 成 加 . 


Restart 


3. Apache 服务 器 的 目录 


正常 情况 下 ，Apache 服 务 器 主 目录 的 预 设 位 置 在 C:\Program Files\Apache Software 
on 径 下 ; 由 于 前 面 安装 时 将 Apache 服 务 器 安装 在 C:\Apache 文 件 夹 中 , 因 
此 主 目录 也 在 C\Apache 路 径 下 ， 打 开 的 二 级 目录 如 图 1-17 所 示 。 
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图 1-17 打开 的 文件 夹 目录 


Apache 服 务 器 各 主 目录 的 意义 与 用 途 说 明 如 表 1-1 所 示 。 


表 1-1 Apache 安 装 文件 夹 说 明 


文件 夹 名 称 主要 功能 

bin 储存 编译 程序 及 指令 文件 

cgi-bin 储存 用 于 设置 支持 cgi 的 文件 

conf 储存 服务 器 结构 档案 ，httpd.conf 文 件 是 设置 服务 器 的 主要 文件 
error 储存 运行 出 错时 提示 用 的 文件 

htdocs 储存 运行 成 功 时 显示 的 文件 ， 该 版 本 就 简单 的 一 行 字 
icons 储存 服务 器 显示 相应 网 页 的 所 有 图 片 文件 

include 储存 支持 服务 器 的 一 些 主要 包含 文件 

lib 储存 Apache 所 需 的 lib 文 件 

logs 储存 日 志 档案 

manual 储存 服务 器 的 模块 功能 文件 

modules 储存 网 页 应 用 程序 的 目录 

prox, 储存 代理 的 功能 模块 


4. 服务 器 的 网 站 目录 


Apache 服 务 器 安装 完成 后 , 需要 将 所 有 PHP 网 站 目录 都 放 到 C:/Apache/Apache 2/htdocs 
文件 夹 内 。 例 如 写 了 一 个 名 为 website 的 PHP 网 站 目录 ， 则 这 个 website 的 网 站 目录 位 置 应 该 
放 到 C:\Apache\Apache 2\htdocs\ 的 资料 夹 中 。 当 然 也 可 以 直接 打开 httpd.conf 文 件 ， 找 到 如 
图 1-18 所 示 的 位 置 ， 将 ServerRoot "C:/Apache/Apache2" 这 一 行 代码 进行 相应 的 设置 即 可 更 


改 为 新 的 网 站 目录 。 


-11- 


图 1-18 设置 网 站 文件 位 置 


进行 到 此 ， 已 经 完成 了 PHP 网 页 开发 环境 Apache 服 务 器 的 安装 。 


1.3 ”PHP 的 安装 与 配置 


在 计算 机 上 安装 完成 Apache 服 务 器 后 ， 就 要 开始 安装 和 配置 PHP 的 执行 环境 ， 
安装 与 配置 有 多 种 方法 ， 这 里 介绍 使 用 PHP 官 方 提供 的 安装 包 来 进行 安装 的 方法 。 


-137 )PHP5 软 件 的 下 载 


安装 好 Apache 服 务 器 以 后 ， 下 面 开始 安装 PHP。PHP 开 发 软件 包 是 开发 PHP 程 序 的 核 
目前 PHP 最 新 的 版 本 


心 ， 该 软件 包 需 要 从 PHP 官 方 网 站 下 载 ， 地 址 为 http://www.php.net。 
是 2013 年 12 月 发 布 的 PHP 5.3.28， 这 里 以 该 版 本 为 例 ， 下 载 的 页 面 如 图 1-19 所 示 。 
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图 1-19 下 载 PHP 的 最 新 安装 版 本 


PHP5.3.28 有 None Thread Safe 与 Thread Safe 两 种 版 本 可 供 选 择 。 这 两 种 版 本 有 何不 同 ， 
作为 使 用 者 来 说 又 应 该 如 何 选择 呢 ? 先 从 字面 意思 上 理解 , None Thread Safe 就 是 非 线 程 安 
全 ， 在 执行 时 不 进行 线程 〈thread) 安全 检查 ; Thread Safe 就 是 线程 安全 ， 执 行 时 会 进行 
线程 (thread) 安全 检查 ， 以 防止 有 新 要 求 就 启动 新 线程 的 CGI 执行 方式 耗 尽 系统 资源 。 再 
来 看 PHP 的 两 种 执行 方式 : ISAPI 和 FastCGI。FastCGI 执 行 方式 是 
所 以 不 需要 进行 线程 的 安全 检查 , 除去 线程 安全 检查 的 防护 反而 可 以 提高 执行 效率 , 所 以 ， 


二 


以 单一 线程 来 执行 操作 ， 


#0 @ 
oi ® 
@ 4 全 可 
如 果 是 以 FastCGI (无 论 搭配 IS 6 或 IIS 7 以 上 更 高 版 本 ) 执行 PHP ， 都 建议 下 载 、 执 行 
Non Thread Safe 版 本 的 PHP 〈PHP 的 二 进位 文档 有 两 种 包装 方式 : msi 、zip ， 请 下 载 zip 


套件 ) 。 而 线程 安全 检查 正 是 为 ISAPI 方 式 的 PHP 准 备 的 ， 因 为 有 许多 PHP 模 块 都 不 是 线程 
安全 的 ， 所 以 需要 使 用 Thread Safe 的 PHP。 本 书 是 使 用 Apache 服 务 器 ， 所 以 要 选择 VC9 版 


本 的 Thread Safe 这 个 PHP 来 安装 。 
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下 载 后 即 可 以 开始 PHP 的 安装 ， 有 具体 的 安装 步骤 如 下 : 

四 双击 下 载 的 文件 php-5.3.28-win32-installer.msi, 弹出 PHP 安 装 程序 欢迎 安装 向 导 对 
话 框 ， 如 图 1-20 所 示 。 


其 PHP 5328 Setup 


Welcome to the PHP 5.3.28 Setup Wizard 


The Setup Wizard wl nstall PHP 5.3.28 on your computer,， 

Canca to et the Setup Wizard. 
Please dicable any wrus detecbon software you may have 
rurnng durng tha nstalabon. 


ea )] [ comeel | 


图 1-20 欢迎 安装 界面 


贺 单 击 [Ce _ | 按钮 ,打开 “End-User License Agreement (终端 用 户 许可 ) ”界面 。 
选中 “I accept the terms in the license Agreement” 复 选 框 ， 同 意 合约 的 授权 ， 继 续 进行 安 


装 ， 如 图 1-21 所 示 。 


| 划 pHp 53.28 Setup 
| 


End User License Agreement 
Please read he folowirg icense agreement carefuly 


The PHP License, version 3.01 
1999 - 2010 The PHP Group. All rights 


taccept the terms in the License Agreement 


图 1-21 同意 安装 


因 单 击 L_ Next] 按钮， 打开 “Destination Folder ( 安装 路 径 文件 ) ”界面 , 单 击 Browse 
(浏览 ) 按钮 来 更 改 PHP 的 安装 路 径 ， 这 里 设置 为 C: \PHP\， 如 图 1-22 所 示 。 


人 
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贡 PHP 53.28 Setup es 


Ee 
id Next to nstal to the defaut folder or cick Browse to dhoose another. 


Instal PHP 5.3.28 to; 


区 而 
ees) 


图 1-22 设置 安装 路 径 


加 设置 PHP 安 装 路 径 之 后 ， 单 击 忆 Red 按钮， 选择 需要 安装 的 Apache 版 本 号 ， 这 
里 为 Apache 2.2x Module， 如 图 1-23 所 示 。 
基 php 5328 Setup |=. 


Web Server Setup 
Select the Web Server you wish to setup. 


Cm Cs ] Cem |] 


图 1-23 选择 Apache 版 本 号 
单 击 [eg 按钮， 设置 Apache 服 务 器 的 安装 路 径 ， 如 图 1-24 所 示 。 


期 PHP 53.28 Setup 


Apache Configuration Directory 
Browse to select the drectory contanng the Apache Configuraton Fies (c... 


Apache Configuraton Drectory: 


FE:Wpache Vpachez\ 


Cas ee) Cons) 


图 1-24 设置 Apache 服务 器 安装 路 径 
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然后 单 击 [Nex 按钮， 打开“Choose Items to Install (选择 安装 项 目 ) ”界面 ， 
选择 要 安装 的 PHP 组 件 ， 设 置 如 图 1-25 所 示 。 


Choose Items to Install 
Select the way you want features to be nstaled 


Chdk the cors in the tree below te change the way feaures wd be nstaled. 


[eowe | 


Reset [see Bek | Mex ] [ce ] 


图 1-25 选择 需 安装 的 PHP 组 件 
: 在 安装 的 时 候 一 定 要 展开 PHP 的 列 选 项 ， 选 拌 MySQL 的 组 件 ， 这 样 才能 把 PHP 和 MySQL 数 据 库 
; 关联 起 来 ， 以 方便 进一步 的 数据 库 连接 使 用 。 i 


设置 完成 后 单 击 [Nex_ 按钮， 打开 “Ready to install PHP ( 准备 安装 ) ”界面 ， 
如 图 1-26 所 示 。 


YE 


Ready to install PHP 5.3.28 Lenpy 


Chdk Install to begn the nstalaton, Cick Back to review or change any of your 
Instalaton settngs. Chdk Cancel to ext the wizard. 


Coe Cr) Ce] 


图 1-26 准备 安装 对 话 框 
国 单 击 Cma 按钮 安装 PHP， 安 装 的 过 程 会 有 安装 进度 提示 ， 如 图 1-27 所 示 。 


SEE 
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© op. 


区 pHp 5328 Setup ee | 


Please wait while the Setup Wizard nstals PHP 5.3.28. 


Status: 


图 1-27 安装 过 程 
国 安装 完成 后 会 显示 完成 对 话 框 ， 提示 成 功 安装 了 PHP 软 件 包 , 单 击 忆 ES] 按钮 完 

成 安装 ， 如 图 1-28 所 示 。 

基 PHP 5328 Setup [= 


Completed the PHP 5.3.28 Setup Wizard 


Cdk the Finish button to ext the Setup Wizard, 


Cas) 


图 1-28 完成 安装 


较 这 是 最 关键 的 一 步 ， 需 要 将 安装 后 的 C:\PHP\ext 文 件 夹 下 的 驱动 都 复制 到 
Ci\WINDOWS\system32 文 件 夹 中 。 


如 果 读 者 在 PHP 官 方 网 站 下 载 的 PHP 软 件 包 非 安 装 程序 而 是 压缩 包 ， 那 么 在 配置 时 需 
要 设置 环境 变量 。 设 置 环 境 变 量 的 具体 方法 如 下 : 


首先 将 PHP 包 解压 到 指定 文件 夹 中 作为 PHP 的 根 目录 ， 例 如 C:\PHP 目 录 中 。 然 后 再 配 
置 Apache 运 行 时 需要 加 载 的 php5apache2_ 2.dll 文 件 。 方 法 是 将 PHP 的 安装 路 径 追 加 到 
Windows 系 统 中 path 路 径 的 下 面 。 右 击 “ 我 的 电脑 ”， 选 择 “ 属 性 ”命令 ， 在 弹出 的 “ 系 
统 属性 ”对 话 框 中 切换 到 “高 级 ”选项 卡 ， 再 单 击 “ 环 境 变 量 ” 按 钮 ， 打 开 “环境 变量 ” 
对 话 框 。 从 “系统 变量 ”列表 中 找到 Path 路 径 ， 单 击 “ 编 辑 ” 按 钮 后 ， 在 弹出 对 话 框 的 “ 变 
量 值 ”文本 框 中 将 “C: \PHP” 追 加 到 路 径 中 即 可 ， 如 图 1-29 所 示 。 
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SystenRootX\systen32; XSyst,| 


C: \WINDONS\systen32\cad exe 

m 

3 

VWindows NT 

CPMNPVIC: MIINDOWS\systen32;C:\... 


(ew (Wm ] mw |] 


图 1-29 编辑 系统 变量 对 话 框 设置 
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安装 完成 PHP 并 不 能 直接 在 Apache 里 运行 PHP 文 件 ， 还 要 进一步 配置 一 下 Apache 才 可 
以 支持 PHP 的 运行 ， 配 置 的 方法 很 简单 ， 方 法 如 下 : 


进入 Apache 服 务 器 的 安装 文件 夹 ， 如 图 1-30 所 示 。 


计算 机 ， Acer (C] ， Apache ， Apache2 » | aspoche7 
4EIR ”包公 到 库 中 ”共享 ” 。 刘 录 新建 
Wine 3 i EE] se A 
Fe bn 2013/12131 1535 mie 
轩 盯 caibin 2013/12131 1535 “ 文 # 闪 
Ed 
erer 
加 二 hdocs 
mn icors 12131 1535 
引 imude 2013/12/311536 ”文中 夫 四 
ed J 2013/12/21 1535 。 文 H 闪 
国庆 loos 2013/12/311535 文 M 实 
中 manual 2013/12131 1%35 文件 天 
Sh modues 
潭 计划 prory 
入 Acer (CY) BABour ApACHE 15K8 
(DY) 目 chanaes 326K8 
a 目 mnsrAu ak 
。 目 uceNse 36K8 日 
了 从 
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1-30 进入 Apache 的 安装 文件 夹 


双击 进入 conf 目 录 ， 打 开 httpd.conf 文 件 ， 在 文件 的 最 下 方 增加 下 面 1 行内 容 (如 图 


1-31 所 示 ) : 


AddType application/x-httpd-php .php 


ee 


ES 
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可 htpd-is 本 es 二 


文人 站“ 思 胆 日 ”“ 柯 XK(O) 豆 看 V) 才 动 H) 


中 
# You may use the conmand line option ’-5’ to verify your virtual host 
# configuretion. 


吕 
# Use nane-based virtual hosting. 


HNaneVirtualHost *:80 


办 
VirtualHost example: 

most ary Apache directive nay go into a VirtualHost container. 
# The first VirtualHost section is used for requests without a knom 
- Server name. 


CVirtualHost *:80> 
ServerAdnin webnaster@dumey-host. example. com 
DocumentRoot /ww/docs/durmy-host. cxanple. com 
ServerNane dummy-host. example. com 

ErrorLog logs/dummy-host. example. com-error_loeg 
CustonLog logs/dummy-host. example. comraccess_10g common 
和 ar 


BEGIN PHP INSTALLER EDITS ~ REMOVE ONLY ON UNINSTALL 
PapIniDir “C:\PEP\” 


图 1-31 加 入 支持 PHP 的 代码 

该 段 代码 中 ， 第 1 行 表示 要 加 载 的 模块 在 哪个 位 置 存储 。 

第 2 行 表 示 PHP 所 在 的 初始 化 路 径 。 

第 3 行 表示 将 一 个 MIME 类 型 绑 定 到 某 个 或 某 些 扩展 名 。.php 只 是 一 种 扩展 名 ， 这 里 可 
以 设 定 为 .html、.php2 等 。 

此 时 PHP 环 境 就 配置 完成 了 。 

辆 同样 查找 DirectoryIndex 这 个 代码 : 将 其 后 面 的 代码 改 为 如 下 

DirectoryIndex index.php default.php index.html 


表示 默认 访问 站 点 时 打开 的 首页 顺序 是 index.php default.php index.html。 
人 1.3.4 )PHP 环 境 的 测试 


PHP 软 件 包 安装 完成 后 ， 就 可 以 在 Apache 中 测试 PHP 环 境 是 否 正 确 了 。 下 面 创 建 一 个 
PHP 示 例 来 测试 ， 该 示例 是 执行 一 个 带 有 PHP 脚 本 的 程序 ， 如 果 执 行 成 功 则 证 明 PHP 安 装 
成 功 。 打 开 Apache 下 的 htdocs 目 录 (这 里 为 C:\Apache\Apache2\htdocs) ， 然 后 使 用 记事 本 
创建 一 个 名 为 testphp 的 文件 ， 再 添加 如 下 代码 到 文件 中 。 


<?PhP 
Phpinfo(); // 输 出 PHP 环 境 信息 
2% 
保存 test.php 文 件 ， 然 后 在 IE 浏 览 器 的 地 址 栏 中 输入 http://localhost/test.php， 如 果 显示 
PHP 的 相关 信息 ， 则 证 明 PHP 软 件 包 和 环境 配置 成 功 ( 如 图 1-32 所 示 〉， 否 则 安装 失败 。 
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图 1-32 ”测试 安装 成 功 显示 的 页 面 


特别 说 明 : 本 书 第 1 版 有 很 多 读者 反馈 装 到 这 一 步 的 时 候 运行 不 了 ， 主 要 是 因为 安装 系 
统 和 环境 不 同 的 结果 ， 为 了 解决 这 一 问题 笔者 建议 初学 者 使 用 集成 环境 ， 如 XAMPP 
(CApache+MySQL+PHP+PERL) 的 官方 网 址 : http://www.apachefriends.org/， 读 者 可 以 下 载 
后 一 次 性 安装 完成 ， 也 不 用 安装 后 面 的 数据 库 。 本 书后 面 的 实例 也 将 使 用 XAMPP 环 境 ， 方 便 
初学 者 学 习 。 


信 必 全 


由 于 刚才 在 前 面 重新 配置 了 Apache 服 务 器 ， 所 以 在 测试 之 前 一 定 要 重启 一 下 Apache 服 务 器 ， 让 
配置 的 功能 能 够 正确 地 使 用 上 。 
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安装 PHP 后 还 可 以 根据 需要 编辑 php.in 文件 ， 对 PHP 的 配置 进行 设置 。 下 面 就 将 对 PHP 
配置 文件 php.ini 的 组 织 方式 进行 简要 的 说 明 。 文 件 命名 为 php.ini 的 原因 之 一 是 它 遵循 许多 
Windows 应 用 程序 中 INI 文件 的 常见 结构 。php.ini 是 一 个 ASCII 文本 文件 ， 并 且 被 分 成 几 个 
不 同名 称 的 部 分 ， 每 一 部 分 包括 与 之 相关 的 各 种 变量 。 

每 一 部 分 类 似 于 如 下 结构 : 

[MySection] 

variable="value" 

anothervariable="anothervalue" 

各 部 分 的 名 称 通过 方 括号 “[ ]” 括 起 来 放 在 顶部 ， 然 后 是 任意 数量 的 “变量 名 = 值 ” 
对 ， 每 一 对 占 单独 一 行 。 如 果 行 以 分 号 “;” 开 头 则 表明 该 行 是 注释 语句 。 

在 php.ini 中 允许 或 禁止 PHP 功 能 变 得 非常 简单 。 只 需要 将 相关 语句 注释 掉 而 无 须 删 除 ， 
该 语句 就 不 会 被 系统 解析 。 特 别 是 当 希 望 在 一 段 时 间 以 后 重新 打开 某 种 功能 的 时 候 特 别 方 
便 ， 因 为 不 需要 在 配置 文件 中 将 此 行 删除 。 

如 下 面 php.ini 文 件 中 的 一 个 片段 : 


= 
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WO 
; Language Options ; 


; Enable the PHP scripting language engine under Apache. 

engine = On 

; Enable compatibility mode with Zend Engine 1 (PHP 4.x) 

zend.zel compatibility mode = Off 

; Allow the <? tag. Otherwise, only <?php and <script> tags are 
recognized. 

; NOTE: Using short tags should be avoided when developing applications 
or 

; libraries that are meant for redistribution, or deployment on PHP 

; Servers which are not under your control, because short tags may not 

; be supported on the target server. For portable, redistributable code, 

; be sure not to use short tags. 

short_open tag = Off 

; Allow ASP-style < 多 $%> tags. 

asp_tags = Off 

; The number of significant digits displayed in floating point numbers. 

precision = 14 

在 这 个 文件 中 可 对 PHP 的 12 个 方面 进行 设置 ， 包 括 : 语言 选项 、 安 全 模式 、 语 法 突出 
显示 、 杂 项 、 资 源 限制 、 错 误 处 理 和 日 志 、 数 据 处 理 、 路 径 和 目录 、 文 件 上 传 、Fopen 包 
装 器 、 动 态 扩 展 和 模块 设置 。php.ini 文 件 存放 在 PHP 的 安装 路 径 ， 在 每 次 启动 PHP 时 都 会 
读 取 。 因 此 ， 在 通过 修改 php.ini 文 件 改 变 PHP 配 置 之 后 ， 需 要 重启 Web 服 务 器 以 使 配置 改 
变 生效 。 本 书 的 实例 需要 配置 的 对 象 为 : 


magic quotes gpc = on 


magic_quotes_gpc 功能 为 : 是否 自动 为 GPC(get,post,cookie) 传 来 的 数据 中 的 \”\”\\ 加 
上 反 斜 线 。 

如 果 magic_quotes_gpc=On， 返 回 1 ，PHP 解析 器 就 会 自动 为 post、get、cookie 过 来 
的 数据 增加 转 义 字符 “”， 以 确保 这 些 数据 不 会 引起 程序 ， 特 别 是 数据 库 语 句 因为 特殊 字 
符 引 起 的 污染 而 出 现 致 命 的 错误 。 

在 magic_quotes_gpc=On 的 情况 下 ， 如 果 输 入 的 数据 有 单 引 号 (”) 、 双 引号 (”) 、 
反 斜 线 (\) 与 NUL (NULL 字符 ) 等 字符 都 会 被 加 上 反 斜 线 ， 这 些 转 义 是 必须 的 。 如 果 
这 个 选项 为 Off， 返 回 0 ， 那 么 我 们 就 必须 调用 addslashes 函 数 来 为 字符 串 增 加 转 义 。 
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PHP 可 以 与 很 多 数据 库 完 美的 结合 ， 从 而 开发 出 动态 网 站 。 对 于 初学 者 而 言 使 用 
MySQL 数 据 库 被 认为 是 容易 上 手 的 数据 库 ， 本 小 节 就 介绍 MySQL 数 据 库 的 下 载 与 安装 知 


识 
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MySQL 是 一 个 真正 的 多 用 户 、 多 线程 SQL 数 据 库 服务 器 。SQL (结构 化 查询 语言 是 
世界 上 最 流行 的 和 标准 化 的 数据 库 语 言 。MySQL 是 以 一 个 客户 机 /服务 器 结构 的 实现 ， 由 
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一 个 服务 器 守护 程序 mysqld 和 很 多 不 同 的 客户 程序 以 及 库 组 成 。 

SQL 是 一 种 标准 化 的 语言 ， 它 使 得 存储 、 更 新 和 存 取信 息 更 容易 。 例 如 ， 能 用 SQL 语 
言 为 一 个 网 站 检索 产品 信息 及 存储 顾客 信息 , 同时 MySQL 也 足够 快 和 灵活 以 允许 你 存储 记 
录 文 件 和 图 像 。 

MySQL 主 要 目标 是 快速 、 健 壮 和 易 用 。 最 初 是 因为 MySQL 创 始 人 需要 这 样 一 个 SQL 
服务 器 一 一 它 能 处 理 与 任何 不 昂贵 的 硬件 平台 上 提供 数据 库 的 厂家 在 一 个 数量 级 上 的 大 
型 数据 库 ， 但 速度 更 快 ，MySQL 因 此 就 开发 出 来 。 自 1996 年 以 来 ，MySQL 一 直 都 在 被 使 
用 ,其 环境 超过 40 个 数据 库 ,包含 10,000 个 表 , 其 中 500 多 个 表 超 过 700 万 行 ,这 大 约 有 100GB 
的 关键 应 用 数据 。 

MySQL 已 用 在 高 要 求 的 生产 环境 多 年 , 尽管 仍 在 开发 中 , 但 它 已 经 提供 了 一 个 丰富 和 
极其 有 用 的 功能 集 。 

在 这 里 推荐 使 用 MySQL 的 主要 原因 在 : 

@ 便宜 (通常 是 免费 ) 。 

网 络 承载 比较 少 。 
经 过 高 度 最 佳 化 (HighlyOptimized ) 。 
应 用 程序 通过 它 做 起 备份 来 比较 简单 。 
为 各 种 不 同 的 数据 格式 提供 弹性 的 接口 。 
较 好 学 且 操作 简单 。 
MySQL 的 优点 有 以 下 几 点 : 
(1) 避免 网 络 阻塞 

针对 多 个 使 用 者 共同 存 取 的 支持 ，MySQL 内 定 最 大 连结 数 为 100 个 使 用 者 。 但 是 ， 纵 

使 网 络 上 有 大 量 数据 往来 ， 似 乎 并 不 会 对 查询 最 佳 化 (query optimization) 有 多 大 的 影响 。 
(2) 最 佳 化 

数据 库 结 构 设 计 也 会 影响 到 MySQL 的 执行 效率 ,例如 MySQL 并 不 支持 外 来 键 (Foreign 
key); 这 个 缺点 会 影响 到 我 们 的 数据 库 设 计 以 及 网 站 的 效率 。 

对 于 使 用 MySQL 做 数据 库 支持 的 网 站 ,应 该 着 重 的 是 如 何 让 硬盘 存 取 减少 到 最 低 、 如 
何 让 一 个 或 多 个 CPU 随时 保持 在 高 速 作业 的 状态 ， 以 及 支持 适当 的 网 络 频 宽 ， 而 非 实际 上 
的 数据 库 设 计 以 及 数据 查询 状况 。 

(3) 多 线程 

MySQL 是 一 个 快速 、 多 线程 Cmultithread) 、 多 使 用 者 上 且 功能 强大 的 关系 型 数据 库 管 
理 系统 (Relational database management system; RDBMS ) 。 也 就 是 说 当 客户 端 与 MySQL 
数据 库 连 接 时 ， 服 务 器 会 产生 一 个 线程 〈thread) 或 一 个 进程 (Process) 来 处 理 这 个 数据 
库 连 接 的 请 求 Crequest) 。 

(4) 可 延伸 性 以 及 数据 处 理 能 力 


MySQL 同 时 提供 高 度 多 样 性 ， 能 够 提供 给 很 多 不 同 的 使 用 者 接口 ， 包 括 命 令 列 、 客 户 
端 操作 、 网 页 浏览 器 , 以 及 各 式 各 样 的 程序 语言 接口 , 例如 C++、Perl、 Java、PHP 以 及 Python。 
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MySQL 可 用 于 Unix、Windows、OS/2 等 平台 ,也 就 是 说 它 可 以 用 在 个 人 计算 机 或 者 是 
服务 器 上 。 


(5) 便于 学 习 


MySQL 支 持 结构 化 查询 语言 (Structured Query Language; SQL) ， 那 么 精通 数据 库 的 
人 在 一 天 之 内 ， 就 可 以 把 MySQL 学 会 了 ， 对 于 初学 者 也 非常 容易 上 手 。 


-人 142 )MySQL 数 据 库 的 下 载 


可 以 到 MySQL 的 官方 网 站 http:/www.mysql.com 下 载 MySQL 的 最 新 版 本 。 下载 MySQL 
数据 库 的 步骤 如 下 : 


贺 打开 IE 浏览 器 , 进入 MySQL 的 官方 网 站 主页 (http://www.mysql.com ) 下 载 MySQL 
数据 库 ， 如 图 1-33 所 示 。 


ar 二 四 Es 
i 


图 1-33 打开 MySQL 主页 
打开 下 载 的 频道 之 后 找到 相关 下 载 文 件 ， 下 载 的 是 MySQL 的 最 新 版 本 mysql-5.6. 
15-win32.msi， 单 击 “Download ( 下载) ”按钮 即 可 下 载 将 要 使 用 的 数据 库 ， 如 图 1-34 所 示 。 
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图 1-34 选择 下 载 的 版 本 


= 


YB, 
MySQL 数 据 库 也 是 不 断 在 更 新 的 ， 对 于 读者 而 言 在 下 载 的 时 候 可 能 版 本 已 经 有 所 改变 , 但 这 并 
不 影响 后 面 的 操作 和 使 用 ， 所 以 可 以 下 载 最 新 的 版 本 进行 安装 使 用 。 


< 1.4.3 )MySQL 数 据 库 的 安装 
下 载 的 安装 包 有 240MB， 具 体 的 安装 步骤 如 下 : 


双击 安装 程序 mysql-5.6.15-win32.msi， 打 开 欢 迎 安装 对 话 框 ， 如 图 1-35 所 示 。 该 
版 本 较 早 期 的 一 些 版 本 的 安装 界面 有 了 很 大 程度 上 的 改变 。 


< 
Welcome MysQL 
The MysQL instaler guldes you through the instalation and Configuraton of your 
ROSE 
Sohet ome ct he octons bor 


ie nc 
ET 


二 


ORACLE 


图 1-35 开始 安装 
贺 单 击 “Install MySQL Products ( 安装 MySQL 产 品 ) ”按钮 以 继续 安装 程序 ， 打 开 
“License Agreement ( 终端 用 户 许可 ) ”界面 。 选 中 “I accept the license terms” 复 选 框 同 
意 合约 的 授权 ， 继 续 进 行 安装 ， 如 图 1-36 所 示 。 


CC MsQt nsaler ee 


MySQL Installer pb ted 


图 1-36 同意 许可 安装 
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加 单 击 忆 see 按钮， 打开 “Find latest products ( 查找 最 新 版 的 产品 ) ”界面 ， 提 
示 安 装 之 前 可 以 连接 到 官方 网 站 进行 核查 并 下 载 更 新 版 的 软件 ， 这 里 选中 “Skip the check 
for updates (not recommended ) ( 跳 过 更 新 ) ” 复 选 框 ， 如 图 1-37 所 示 。 
Wal met I | 


Se Find latest products 
MySQL. Installer Li 


Before the metalation 5 Derfomaed, he nstatiy wl cherk ¥ there are vem 
he products you are about ro Insral / already msrallad are avalable 


© Comect bo he micnet 
© Fekhpodet pdate rfomesomn 


Sep ee heck tor pcstae oot recormerded) 


a Es Es 
图 1-37 ” 跳 过 更 新 设置 

加 单 击 忆 wet | 按钮 打开 “Choosing a Setup Type (选择 安装 类 型 ) ”界面 ， 选 择 

MySQL 的 安装 类 型 为 “Custom ( 自 定 义 ) ”， 同 时 将 路 径 改 为 CNMySQL， 如 图 1-38 所 示 。 

ee) 


[wa re 


AN Choosil Setup T, 
MysQE Installer 


Peace salect the Setup TYpa that suts your use cace 


图 1-38 设 定安 装 类 型 和 目录 安装 


加 确认 后 ， 单 击 [Nex _] 安 入 ， 打 开 “Feature Selection (安装 选择 ) ”界面 ， 在 这 
里 建议 保持 安装 的 默认 值 ， 即 选中 所 有 的 安装 复 选 框 ， 如 图 1-39 所 示 。 
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回 wysQL Installer 


RN Feature Selection 
MySQL. Installer 


Please select the products and features you would like to install on this macdhine 
Product Gtsbog: Archtecture: 


回 we enesss 
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图 1-39 选择 安装 软件 


四 单 击 忆 wet 按钮， 打开 “Check Requirements (检查 组 件 ) ”对 话 框 ， 在 该 对 话 
框 中 要 求 安装 的 环境 中 必 须 有 .NET Framework 4 和 Visual C++ 等 开发 组 件 ， 如 图 1-40 所 示 。 


回 wsaQt inaaler 


[Ex 一 


NN 
MySQL Installer elie 


The folowing requirements must be installed before the selected products can be 
installed. If you dor't want a particular requirement then go back and deselect the 


that requires it. 
Reqrement For Product Statue 
TF Mcrosoft pxcel 2007 or greater MysQ For pxcel L13 


Proflle MysQL Nonfer LL4 
2-bt rntime MYSQL Wortbench CE 6.0.8 
rework 4 Client Profile MySQL Workbench Ct 

‘sual Stucio 2068, 2010, 2012 MySQL fer Visual Saudio 1.02 


Check Recuiramenta 


Gurrent Task 


The Product MySQL for Vieual Studio 1.0.7 requres ‘Vieual Studio 2008, 2010, 2012" but it was 


El EE El 


图 1-40 ”提示 要 安装 的 组 件 


如 果 你 的 计算 机 中 没有 安装 相应 的 组 件 ， 单 击 [CEsxe 按钮 ， 则 安装 程序 就 会 自动 
从 互联 网 下 载 相应 的 组 件 安装 程序 ， 下 载 的 进度 提示 如 图 1-41 所 示 。 
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Check Requirements 


pi Installer 


The following requirements must be installed before the selected products can be 
installed. I you don't want a particular requirement then go back and deselect the 
product that requires it. 


Rearement For oduct EE 
© Microsoft .NET Framework4 Client Profile MySQL Workbench CE 5.2.39 
® Microroft Visual C++ 2010 32-bit mime wysQL Workberch cE S230 [BE] 


Check Requirements 


Current Task 
Downlosding Microsoft visual c++ 2010 22 btruntme 


图 1-41 设 定安 装 类 型 和 目录 安装 
国 下 载 成 功 后 会 自动 弹出 相应 组 件 的 开始 安装 对 话 框 ， 这 里 以 安装 Microsoft Visual 
C++ 2010 为 例 。 打 开 安 装 对 话 框 ， 选 中 “我 已 阅读 并 接受 许可 条 款 ” 复 选 框 ， 如 图 1-42 
所 示 。 


Ye C++ 2010 x86 Redistributable .-。 必 


欢迎 使 用 Bi creseft Visasl Ct+ 2010 z86 Redistribatsble 安装 程序 
请 接受 许 可 条 款 以 继续 [> <】 


MICROSOFT 软 件 许可 条 款 
MICROSOFT VISUAL C++ 2010 RUNTIME LIBRARIES 


加 归 已 同 于 并 近江 许可 于 蒜 CA)*] 


口 是 ， 向 此 crosoft Corporation 发 送 有 关 我 的 安装 体验 的 信息 站)。 
有 关 详细 信息 ， 请 阅读 数据 收集 第 咯 。 


图 1-42 接受 安装 许可 对 话 框 
国 单 击 “ 安 装 ” 按 钮 ， 打开 “安装 进度 ”对 话 框 ， 由 于 只 是 安装 简单 的 环境 组 件 ， 
并 不 需要 进行 复杂 的 配置 ， 只 需 等 待 安装 即 可 ， 如 图 1-43 所 示 。 


ep 


icrosoft Yisual C++ 2010 xz85 FE 


正在 安装 出 crosoft Visod ctt 2010 x06 1edistribstatle ,请 CCD 


文件 安全 验证 
IIIIIIIOODD 
已 砚 功 驻 下 所 有 文件 


Wisnal CH 2010 Redistribetable 


图 1-43 ”安装 组 件 的 过 程 
四 安装 结束 后 会 弹出 “安装 完毕 ”对 话 框 ， 如 图 1-44 所 示 。 
icrosoft Visual C++ 2010 x86 Redistributable ... 
安装 完毕 


已 安装 Microsoft Visusl CH 2010 x86 
Bedistributsble, 


VED 
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图 1-44 设 定安 装 类 型 和 目录 安装 


国 单 击 “完成 ”按钮 ， 完 成 组 件 的 安装 ， 这 时 在 原来 “Check Requirements ( 检查 组 
件 ) ”界面 中 的 组 件 就 自动 名 选 上 了 ， 如 图 1-45 所 示 。 
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图 145 组 件 安 装 完成 
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单 击 CNex  ] 掖 钮 ， 打 开 “Installation Progress (安装 进程 ) ”界面 ， 对 话 框 中 显 
示 了 即将 安装 软件 的 进度 为 “To be installed (即将 被 安装 ) ”状态 ， 如 图 1-46 所 示 。 


回 wsot Installer 
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Installation Progress 
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图 146 提示 即将 安装 


单 击 [Ese 按钮 ， 则 安装 程序 会 自动 开始 安装 所 有 的 程序 并 提示 安装 的 进程 ， 如 


图 1-47 所 示 。 
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Installation Progress 


The following products will be instalied or updated. 
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Show Detale > 


图 1-47 安装 的 进程 


安装 完成 时 当 所 有 安装 选项 前 面 都 打上 对 勾 ， 则 表示 该 程序 安装 成 功 ， 安 装 完成 


的 对 话 框 如 图 1-48 所 示 。 
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AN Installation progress 
MySQL Installer 

The folowng products wll be nstalled or updated. 

Prodct seus Drogess notes | 
@ ws snesss eol socress 
@ 国 we wmaeus stn uctess 
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ET 
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图 1-48 安装 完成 的 对 话 框 


四 单 击 [Next 按钮， 打开 “Configuration Overview ( 确认 预览 ) ”界面 ， 提 示 安 
装 的 MySQL 数 据 库 将 要 进行 确认 ， 如 图 1-49 所 示 。 


[wsor rae | 
AN Configuration Overview 
MySQL. Installer 
The folowing products wll now be confoured 
Pode Meion whe erformed oues 
证 回 wasrwsss eal Configuaten 
ev ookey 
a Es 


1-49 “Configuration Overview (确认 预览 ) ”界面 
国 单 击 [Nex 上 按钮 ， 打开 “MySQL Server Configuration ( 数据 库 确认 ) ”界面 ， 
提示 选择 数据 库 服务 器 的 安装 类 型 ， 这 里 选中 “Developer Machine ( 开发 者 机 器 ) ” 单 选 
按钮 ， 其 中 “Enable TCP/IP Networking (设置 TCP/IP 工 作 方式 的 选项 ) ”表示 将 MySQL 
数据 库 服务 器 注册 为 TCP/IP 的 服务 以 方便 管理 ， 同 时 端口 为 3306， 如 图 1-50 所 示 。 


7 


全 
i [os sie 网 站 开 入 全 程 实例 (第 2 版 ) 


回 wsat rstaller 
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图 1-50 设 定安 装 类 型 和 目录 安装 


选择 确认 模式 后 再 单 击 [_Nex 按钮， 打开“MySQL Server Configuration (数据 
库 确 认 )” 界 面 的 第 二 步 , 两 次 输入 前 面 安装 时 设置 的 root 密 码 ( 这 里 设置 的 密码 为 admin， 
后 面 章节 数据 库 登 录 全 是 使 用 admin ) ， 具 体 的 设置 如 图 1-51 所 示 。 
Esa neor [=1 -mi 


MySQL Server Configuration 213 


RN 
MySQL Installer 


ET 


Ce es 


图 1-51 确认 安全 设置 


国 设置 完成 后 ， 单 击 忆 et 按钮， 打开 “MySQL Server Configuration ( 数据 库 确 
认 ) ”界面 的 第 三 步 “Windows Service Details ( Windows 操 作 系统 细节 设置 ) ”， 保 持 默 
认 值 ， 如 图 1-52 所 示 。 
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MySQL Server Configuration 313 


TS 
MySQL. Installer 


Windows seruice Details 


和 


WindowsServiceName: WERE 


7) Start the HysQL Server at System Startup 


Ry Run Windows Service as 


图 1-52 ”Windows 操作 系统 细节 设置 


四 单 击 [Next 按钮， 打开 “Configuration Overview ( 确认 预览 ) ”界面 ， 如 果 前 
面 的 设置 和 安装 全 部 正确 ， 则 安装 的 选项 前 面 将 会 显示 对 义 ， 如 图 1-53 所 示 。 


回 WsQ netaller l=- 
NS Configuration Overview 
MySQL Installer 
The following products wil now be configured, 
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研 
ET 
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图 1-53 确认 预览 面板 


团 确认 后 再 单 击 L_Next | 按钮 ， 打开 最 后 的 “Installation Complete ( 完成 安装 ) ” 界 
面 , 单 击 选择 “Star MySQL Workbench after Setup ( 完成 安装 后 启动 MySQL 的 工作 界面 ) ” 
复 选 框 ， 如 图 1-54 所 示 。 
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回 wysQt Installer ET 
RN Installation Complete 
MysQL. Installer 
The instalation procedure has been completed. 
EEC 
start MysQ Wortbend after Setup 
Cr 
图 1-54 ”完成 安装 的 对 话 框 
安装 完成 后 ， 单 击 志 BE 按钮 ，MySQL 数 据 库 的 安装 就 完成 了 。 用 上 述 的 方法 安装 
完 数 据 库 后 打开 C 盘 下 的 MySQL/MySQL Server5.6/Date 文 件 夹 ， 如 图 1-55 所 示 。 
总 一 一 | 
OO HE» heer (CO) ，MsQL，MWsQtcever56 » do ， BE EZ P| 
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图 1-55 数据 库 的 存放 位 置 


该 文件 夹 表示 数据 库存 放 的 默认 的 位 置 ， 即 后 面 章节 所 有 制作 的 实例 的 数据 库 就 可 以 


直接 放 在 这 里 。 


2 15 ” MySQL 数据 库 的 管理 


在 安装 完 MySQL 数 据 库 后 ， 可 以 自动 运行 数据 库 的 管理 软件 MySQL Workbeach， 如 
很 精通 的 学 习 者 在 使 用 上 有 一 
定 的 难度 。 在 国内 比较 普及 的 针对 MySQL 数 据 库 进 行 管理 的 还 有 好 几 款 软件 ， 其 中 


图 1-56 所 示 。 该 数据 库 管 理 软 件 是 英文 版 的 ， 对 于 英语 不 是 


phpMyAdmin 是 最 简单 的 网 页 版 ， 由 于 本 软件 有 中 文 版 ， 配 置 也 非常 的 简单 ， 这 号 
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有 推荐 使 


用 phpMyAdmin 对 MySQL 数 据 库 进 行 管 理应 用 ， 如 图 1-56 所 示 。 
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图 1-56 ”MySQL Workbeach 主 界面 


和 ”1.5.1 )phpMyAdmin 的 下 载 


phpMyAdmin 就 是 一 种 MySQL 的 管理 工具 ， 安 装 该 工具 后 ， 即 可 以 通过 Web 形 式 直 接 
管理 MySQL 数 据 , 不 需要 通过 执行 系统 命令 来 管理 ,非常 适合 对 数据 库 操作 命令 不 熟悉 的 
数据 库 管 理 者 ， 下 面 就 从 phpMyAdmin 官 网 上 下 载 该 软件 。 

下 载 的 步骤 如 下 : 

加 打开 phpMyAdmin 的 官方 站 点 : http:/www.phpmyadmin.net/ ， 在 页 面 中 单 击 

“Download (下载) ”进入 下 载 频道 ， 如 图 1-57 所 示 。 
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图 1-57 下 载 phpMyAdmin 频道 
贺 选择 最 新 的 版 本 单 击 “Download 4.1.3” 文 件 包 进行 下 载 ， 如 图 1-58 所 示 。 
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图 1-58 选择 下 载 的 文件 包 
下 载 后 的 ZIP 文 件 通过 解压 软件 解压 到 本 地 硬盘 。 如 果 本 地 有 MySQL 则 可 在 本 地 
测试 ， 这 里 将 所 有 解压 文件 复制 到 C:\Apache\Apache2\htdocs 文 件 夹 内 ， 如 图 1-59 所 示 。 则 
可 通过 “http://localhost/phpmyadmin” 进 行 访问 。 
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图 1-59 解压 缩 到 Apache 站 点 文件 内 
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无 论 是 在 本 地 测试 还 是 在 远程 服务 器 上 测试 ， 都 需要 进行 如 下 的 文件 配置 才能 正常 使 
用 phpMyAdmin。 
配置 的 方法 也 比较 简单 ， 具 体 的 配置 步骤 如 下 : 


在 下 载 解压 下 来 的 文件 中 查找 到 文件 config.sample.inc.php, 这 是 phpMyAdmin 配 置 
文件 的 样本 文件 ， 需 要 把 该 文件 中 的 所 有 代码 复制 ， 新 建 一 个 文件 config.inc.php， 并 将 代 
码 粘 贴 。 文 件 config.inc.php 是 phpMyAdmin 的 配置 文件 ， 上 传 服务 器 时 必须 上 传 该 文件 ， 
如 图 1-60 所 示 。 
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图 1-60 创建 config.inc.php 文 件 


对 于 config.inc.php 文 件 ， 最 重要 的 是 修改 加 入 phpMyAdmin 连 接 MySQL 的 用 户 名 
和 密码 ， 寻 找到 代码 行 : 


PHP 代 码 


// $cfg['Servers'] [$i]['controluser'] = 'Pma'， 
// $cfg['Servers'] [$i]['controlpass'] = 'pmapass', 
// $cfg['Servers'] [$i]['controluser'] = 'pma'; 


// $cfg['Servers'] [$i]['controlpass'] 


将 “//” 注 释 号 删除 ， 同 时 输入 MySQL 中 配置 的 用 户 名 和 密码 (3 
你 的 空间 服务 商 ) 


PHP 代 码 


'pmapass', 


比如 这 里 : 


$cfg['Servers'] [$i]['controluser'] = 'root',; 
$cfg['Servers'] [$i]['controlpass'] = 'admin'; 
$cfg['Servers'] [$i]['controluser'] = 'root'; 


$cfg['Servers'] [$i]['controlpass'] 


中 大 太太 认 关 大量， 


修改 后 的 文档 如 图 1-61 所 示 。 
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图 1-61 修改 用 户 名 和 密码 
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如 果 需 要 通过 远程 服务 器 调试 使 用 phpMyAdmin， 则 需要 添加 blowfish_secret 内 容 


定义 Cookie， 寻 找到 代码 行 : 
PHP 代 码 


$cfg['blowfish secret'] 
// 设 置 内 容 为 Cookie 


修改 为 : 
$cfg['blowfish secret'] 


设置 后 如 图 1-62 所 示 。 
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图 1-62 设置 Cookie 权限 
phpMyAdmin 的 使 用 


在 下 浏览 器 中 输入 http://127.0.0.1/phpmyadmin/ 


息 ， 如 图 1-63 所 示 。 


即 可 以 进入 软件 的 管理 界面 ， 选 择 
相关 数据 库 可 看 到 数据 库 中 的 各 表 ， 可 进行 表 、 字 段 的 增删 改 ， 可 以 导入 、 导 出 数据 库 信 
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图 1-63 软件 的 管理 界面 
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MySQL 数 据 库 的 管理 软件 有 很 多 , 读者 也 可 以 下 载 一 些 其 他 常用 的 软件 进行 管理 , 对 
于 初学 者 而 言 建议 使 用 phpMyAdmin 软 件 。 


1 16 ， 集成 环境 XAMPP 安 装 和 使 用 


XAMPP (Apache+ MySQL+PHP+PERL) 是 一 个 功能 强大 的 建站 集成 软件 包 。 这 个 软 
件 包 原来 的 名 字 是 LAMPP， 但 是 为 了 避免 误解 ， 最 新 的 几 个 版 本 就 改名 为 XAMPP 了 。 
它 可 以 在 Windows、Linux、Solaris 三 种 操作 系统 下 安装 使 用 ， 支 持 多 语言 : 英文 、 简 体 中 
文 、 繁 体 中 文 、 韩 文 、 俄 文 、 日 文 等 。 


-全 167 )XAMPP 集 成 套件 的 下 载 安装 

XAMPP 也 是 笔者 用 到 现在 为 止 感觉 最 好 用 的 一 款 APACHE+MYSQL+PHP 套 件 了 。 同 
时 支持 Zend Optimizer， 支 持 插 件 安装 ， 编 写本 书 时 最 新 XAMPP 的 版 本 是 1.8.1。 下 载 的 方 
法 如 下 : 

打开 IE 浏览 器 ， 输 入 官方 网 址 : http://www.apachefriends.org/， 按 回 车 键 后 ， 进 入 
到 下 载 页 面 如 图 1-64 所 示 。 
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XAMPP Apache + MySQL + PHP + 
Perl 


什么 是 XAMPP? 
流行 的 PHP 开 发 环境 
MAMPP 有 从 则 于 人 二 Aeeche 间 和 全， 其 中 公有 MSOL、PHPHOPerl。 XAMPP 才 各 和 的 不 关 和 


本 么 要 使 用 XAMPP? 


图 1-64 进入 下 载 页 面 


四 单 击 页 面 上 的 “XAMPP for Windows (适用 于 Windows 的 XAMPP ) ”文字 链接 ， 
即 开始 下 载 。AMPP 是 完全 免费 的 ， 并 且 遵循 GNU 通 用 公众 许可 协议 ，XAMPP 目 前 包含 
的 功能 模块 如 下 : 


Apache 2.4.3 

$5.5.27 

PHP 5.4.7 

phpMyAdmin 3.5.2.2 

FileZilla FTP Server 0.9.41 

Tomcat 7.0.30 (with mod_proxy_ajp as connector) 
Strawberry Perl 5.16.1.1 Portable 
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‘© XAMPP Control Panel 3.1.0 (from hackattack142) 
< 762 )XAMPP 的 安装 测试 过 程 

XAMPP 的 安装 过 程 很 简单 ， 解 压 包 等 就 更 简单 一 点 。 这 里 以 Windows 7 操作 系统 中 安 
装 XAMPP 为 例 ， 其 步骤 如 下 : 

安装 时 最 好 放置 到 D 盘 ， 不 建议 放 到 系统 盘 去 ， 尤 其 是 早期 的 XAMPP 版 本 可 能 默 


认 安 装 在 Program files 下 ， 在 Vista、Windows 7 可 能 需要 修改 写 入 权限 ， 双 击 下 载 的 文件 安 
装 包 ， 打 开 如 图 1-65 所 示 的 提示 安装 注意 事项 。 


Important! Because an activated User Account Control (UAC) on your 
sytem some functions of XAMPP are possibly restricted. With UAC please 
avoid to install XAMPP to CNProgram Files (missing write permisssions). 


Or deactivate UAC with msconfig after this setup. 


图 1-65 开始 安装 


贺 如 果 是 第 一 次 安装 ， 或 者 系统 上 没有 装 有 Microsoft Visual C++ 2008 组 件 时 ， 会 提 
示 先 下 载 该 组 件 对 话 框 ， 如 图 1-66 所 示 。 


Warning: XAMPP (PHP) cannot work without the Microsoft Visual C++ 
2008 Redistributable Package. Now open the Microsoft page for this 
download? 


Ca |) (eswa) 


图 1-66 提示 下 载 组 件 
这 里 是 第 一 次 安装 ， 因 此 单 击 “ 是 ”按钮 ， 自 动 打开 浏览 器 并 链接 到 下 载 页 面 ， 
选择 中 文 (简体 ) 版 ， 再 单 击 “ 下 载 ” 按 钮 ， 如 图 1-67 所 示 。 


快速 链接 Microsoft Visual C+ + 2008 SP1 Redistributable 
3 Package (x86) 会 为 Visual C+ + 库 安装 必要 的 运行 时 组 
“村 六 委 求 件 ， 使 用 户 能 够 在 未 支 装 Visual C+ + 2008 SP1 的 计算 机 
0 上 潜行 使 用 Visual C++ SP1 开发 的 应 用 程序 
快速 详细 信息 

Microsoft Ee: sR: 20083N6 
Store mane: sm 
| EF- a 
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图 1-67 ”下载 相应 的 组 件 
下 载 后 先 安装 下 载 的 组 件 , 完成 安装 之 后 切换 回 XAMPP 的 安装 步 难 , 提示 将 开始 
安装 XAMPP 组 件 ， 如 图 1-68 所 示 。 
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Welcome io the XAMPP 18 1 Setup 
Wizard 
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图 1-68 开始 安装 面板 
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图 1-69 选择 安装 的 组 件 
罗 单 击 Next (下 一 步 ) 按钮 ， 打 开 “Choose Install Location (选择 安装 路 径 ) ”对 话 
框 ， 这 里 选择 在 D 盘 下 安装 ， 设 置 如 图 1-70 所 示 。 


XAMPP 1.8.1 win32 


Choose Install Location 
Choose the folder in which to nstal XAMPP 1.8.1. 


Setup wil instal XAMPP 1.8. 1in the folowing folder. To install in a different folder, dick 
Browse and select another folder. Cick Instal to start the instaliation. 


图 1-70 选择 安装 路 径 
Vista 以 上 操作 系统 用 户 请 注意 : 由 于 对 Vista 默认 安装 的 C:\program files 文 件 夹 没有 
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加 单 击 Next (下 一 步 ) 按钮 ， 打 开 “Choose Components ( 选择 安装 组 件 ) ”对 话 框 ， 
这 里 保持 默认 值 即 匀 选 所 有 的 组 件 进行 安装 ， 如 图 1-69 所 示 。 
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足够 的 写 权限 , 推荐 为 XAMPP 安装 创建 新 的 路 径 , 如 D:\XAMPP 或 D:\myfolder\XAMPP。 


加 设置 完 路 径 之 后 ， 再 单 击 “Install (安装 ) ”按钮 ， Mo 
上 ， 安装 的 组 件 比 较 多 ,， 近 700MB， 需 要 耐心 等 上 几 分钟 ， 安 装 的 过 程 提示 如 图 1-71 所 示 。 


加 XAMPP 181 win32 


Iinstalling 


Please wait whie XAMPP 1.8.1i being nstaled, 


Extract: phpexamples. php 

1 
Extract: th.php 

Output foider: D: Vampp\htdocs Wampp maviinks 
Extract: 01_phpmyadmin.tools 


图 1-71 安装 过 程 提示 
国 安装 完成 后 , 会 弹出 COMMAND 设 置 窗口 ,进行 文件 的 最 后 确认 ,如 图 1-72 所 示 ， 
这 里 不 需要 进行 任何 的 操作 ， 以 前 的 版 本 就 需要 根据 提示 进行 一 些 设置 。 


图 1-72 DOS 窗口 下 的 配置 
国 配置 完毕 后 弹出 完成 安装 的 窗口 ， 如 图 1-73 所 示 。 


XAMpp 1a1 wn32 | 


Completing the XAMPP 1.8.1 Setup 
Wizard 


[em 


图 1-73 ”完成 安装 对 话 框 


= 


到 这 里 XAMPP 就 安装 完成 了 ， 如 果 出 现 XAMPP 安 装 失败 ， 请 先 运行 安 装 一 半 的 
XAMPP 目 录 下 的 孝 载 文件 uninstall xampp.bat 执 行 一 次 清理 , 然后 再 重新 安装 。 单 击 “Finish 
(完成 ) ”按钮 ， 弹 出 是 否 启 动 XAMPP 确 认 面板 对 话 框 ， 如 图 1-74 所 示 。 
下 面 我 们 来 看 一 下 XAMPP 的 控制 面板 ， 单 击 面板 上 各 软件 组 件 后 面 的 Star 按 钮 ， 
弹出 “Windows 安 全 警报 ”对 话 框 ， 全 部 选择 “允许 访问 ”按钮 ， 如 图 1-75 所 示 。 


回 xAaMpp 18.1 win32 


You can manage all the servers (services) with the XAMPP Control Panel 
Do you want to start the Control Panel now? 


Gm) (saw) 


图 1-74 ”打开 XAMPP 确认 面板 图 1-75 设置 允许 访问 
国 开启 Apache、MySQL 两 个 核心 程序 , 最 后 设置 完毕 的 对 话 框 如 图 1-76 所 示 。 图 中 ， 
可 以 看 到 XAMPP 的 一 些 基本 控制 功能 ， 注 意 不 建议 把 这 些 功 能 注册 为 服务 (开机 启动 ) ， 
每 次 使 用 的 时 候 自己 就 当 个 软件 运行 就 可 以 了 ( 桌面 上 已 经 有 图 标 ) ， 这 样 在 不 使 用 


XAMPP 时 更 节省 资源 。 
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图 1-76 ”启动 组 件 服务 


启动 成 功 之 后 打开 IE 浏 览 器 ， 输 入 服务 器 默认 IP 地 址 : 127.0.0.1， 回 车 之 后 打开 
如 图 1-77 所 示 的 欢迎 界面 ， 说 明 就 已 经 安装 成 功 可 以 开始 使 用 。 
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图 1-77 欢迎 界面 

这 里 要 特别 说 明 的 是 : 对 初学 者 而 言 开发 后 的 PHP 网 站 程序 不 知道 放 在 哪里 ， 其 实 很 
简单 只 要 将 整个 网 站 程序 放 在 htdocs 文 件 夹 下 就 可 以 进行 访问 了 ， 如 图 1-78 所 示 。 同 样 要 
将 数据 库 文 件 放 在 Mysql/date 文 件 夹 底下 ， 同 时 数据 库 的 连接 用 户 名 要 为 root， 密 码 为 空 
(XAMPP 默 认 安 装 下 的 用 户 名 和 密码 〉。 


图 1-78 网 站 所 放置 的 位 置 
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XAMPP 安 装 完成 之 后 进行 使 用 的 方法 如 下 : 
(1) XAMPP 的 启动 路 径 : xampp\xampp-control.exe 
(2) XAMPP 服 务 的 启动 和 停止 脚本 路 径 。 


启动 Apache 和 MySQL: xampp\xampp_start.exe 
停止 Apache 和 MySQL: xampp\xampp_stop.exe 
启动 Apache: xamppvapache _start.bat 

停止 Apache: xamppvapache_stop.bat 

启动 MySQL: xampp\mysql_ start.bat 

停止 MySQL: xampp\mysql]_ stop.bat 

启动 Mercury 邮件 服务 器 : xamppvmercury_start.bat 


yb 


@ 设置 FileZilla FTP 服务 器 : xampp\filezilla_setup.bat 
@ 启动 FileZilla FTP 服务 器 : xampp\filezilla_start.bat 
@ 停止 FileZilla FTP 服务 器 : xampp\filezilla_stop.bat 


(3) XAMPP 的 配置 文件 路 径 。 


Apache 基本 配置 : xampp\apache\conf\httpd.conf 

Apache SSL: xampp\apache\conf\ssl.conf 

Apache Perl ( 仅 限 插件 ) : xampp\apache\conf\perl.conf 
Apache Tomcat ( 仅 限 插件 ) : xampp\apache\conf\java.conf 
Apache Python ( 仅 限 插件 ) : xampp\apache\conf\python.conf 
PHP: xampp\php\php.ini 

MySQL: xampp\mysql\bin\my.ini 

phpMyAdmin: xampp\phpMyAdmin\config.inc.php 

FileZilla FTP 服务 器 : xampp\FileZillaFTP\FileZilla Server.xml 
Mercury 邮件 服务 器 基本 配置 : xampp\MercuryMaiNMERCURY.INI 
Sendmail: xampp\sendmail\sendmail.ini 


(4) XAMPP 的 其 他 常用 路 径 。 

@ 网 站 根 目 录 的 默认 路 径 : xampp\htdocs 

@ MYSQL 数据库 默认 路 径 : xampp\mysql\data 

(5) 日 常 使 用 只 需要 使 用 XAMPP 的 控制 面板 即 可 ， 可 以 随时 控制 apache、PHP、 
MYSQL 以 及 FTP 服 务 的 启动 和 终止 。 

(6) 附 XAMPP 的 默认 密码 

@ MySQL 

User: root Password: ( 空 ) 


© FileZilla FTP 

User: newuser Password: wampp 

User: anonymous Password: some@mail.net 
@@ Mercury 


Postmaster: postmaster (postmaster@localhost) 
Administrator: Admin (admin@localhost) 
TestUser: newuser Password: wampp 


@@ WEBDAV 


User: wampp Password: xampp 


参照 上 文 XAMPP 安 装 和 配置 完成 后 ， 就 可 以 安装 Dreamweaver 等 网 页 程序 编辑 软件 ， 
进行 网 页 编程 测试 了 。 


本 


第 章 


PHP 的 基本 语 ; 


PHP 是 一 种 创建 动态 交互 性 站 点 的 强 有 力 的 服务 器 端 脚本 语言 。 既 然 是 脚本 语言 ， 
那么 在 使 用 之 前 我 们 就 要 学 习 PHP 的 基本 语法 ,只 有 掌握 了 基本 语法 才 可 以 方便 地 进行 动 
态 网 站 的 开发 。PHP 语法 非常 类 似 于 Perl 和 C， 对 于 有 相关 经 验 的 读者 可 以 非常 轻松 
地 掌握 ， 本 章 就 介绍 一 些 PHP 的 基本 语法 ， 包 括 变量 、 常 量 、 运 算 符 、 控 制 语 句 以 及 数组 
等 ， 通过 学 习 这 些 基础 知识 使 读者 能 更 深入 地 了 解 PHP， 并 能 在 后 面 的 章节 中 轻松 开发 出 
动态 网 页 。 


本 章 的 学 习 重 点 
@ PHP 基 础 程序 结构 
@ PHP 表 单 变量 的 使 用 
@ PHP 程 序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 
@ 掌握 MySQL 数 据 库 的 操作 


> 2.1 ”PHP 基 础 程序 结构 


在 编写 动态 网 页 程序 时 可 以 将 HTML 标 记 与 这 些 动态 语言 代码 混合 到 一 个 文件 中 ， 通 
过 使 用 一 些 特殊 的 标识 将 两 者 区 别 开 来 ， 如 ASP 使 用 的 是 <%%>。PHP 也 是 如 此 ， 可 以 与 
HTML 标 记 共 存 ，PHP 提 供 了 多 种 方式 来 与 HTML 标 记 区 别 ， 可 以 根据 自己 的 习惯 选择 一 
种 ， 也 可 以 同时 使 用 几 种 。 本 小 节 就 介绍 一 下 PHP 的 基础 程序 结构 ， 包 括 输出 和 注释 的 方 


< 基础 程序 结构 


PHP 程 序 结构 和 Perl 以 及 C 一 样 ， 结 构 比 较 严谨 ， 需 要 在 每 条 语句 后 使 用 分 号 “;” 来 作 
为 结束 ， 而 且 对 语句 中 的 大 小 写 敏感 。 
常用 的 方式 有 如 下 3 种 : 


方法 一 : PHP 标准 结构 推荐) 
<?php 
Echo "这 是 第 一 个 PHP 程 序 !"; 
2 


方法 二 : PHP 的 简短 风格 (需要 设置 php.ini) 
<?Echo "这 是 第 一 个 PHP 程 序 !"; ?> 


方法 三 : PHP 的 Script 风格 〈 宛 长 的 结构 ) 
<script language="php">echo" 这 是 第 一 个 PHP 程 序 !"; </script> 


在 C:\XAMPP\htdocs\ 建 立 一 个 php 文 件 夹 用 来 保存 本 章节 的 实例 ， 将 本 实例 保存 为 
pg001, 刚 开始 创建 文档 时 都 用 记事 本 进行 编写 , 保存 为 .php 文 件 即 可 , 运行 的 结果 如 图 2-1 
所 示 。 

/2 http://127.0.0.1/php/pg001. php Windows Internet Explorer 


GO Bremen 
文件 中。 凡 辑 下 ) 查看) 收 基 天 () 工具 CD) 和 帮助 0D 
席 蕊 http://127.0.0 1/php/panol php 


这 是 第 一 个 PHP 程 序 ! 


图 2-1 输出 的 第 一 个 程序 
实际 开发 时 ， 第 1 种 和 第 2 种 是 最 常用 的 方法 ， 即 : 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 
码 ， 在 程序 代码 的 最 后 ， 使 用 问号 及 大 于 号 作为 结束 。 第 3 种 方法 有 点 类 似 于 JavaScript 的 
编写 方式 。 


a 


bes )。 网 站 开发 全 程 实例 (第 2 版 ) 
SS 
3 op. 


人 2.1.2 ) 打 印 输出 结果 

PHP 输 出 所 有 参数 可 以 用 echo0 命 令 ，echo0 实 际 上 不 是 一 个 函数 〈 它 是 一 个 语言 结 
构 ) ， 因此 不 是 一 定 要 使 用 小 括号 来 指明 参数 ， 单 引号 ， 双 引号 都 可 以 。echo0 不 像 其 他 
语言 构造 表现 得 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另外， 如 果 想 给 echo() 
传递 多 个 参数 ， 那 么 就 不 能 使 用 小 括号 。 


也 可 以 使 用 printO 命 令 来 实现 ， 但 echo0) 函 数 比 print(O) 函 数 速度 运行 快 一 些 。 


举例 用 PHP 输 出 语句 ， 包 括 HTML 格 式 化 标签 : 


<?php 
Echo "<p> 这 是 我 输出 打印 的 第 一 个 文档 。</p>"; 
?> 


输出 的 结果 如 图 2-2 所 示 。 
(ES http://127. 0. 0. I/php/pg002.php — Windows Internet Erplorer 


[oS 
文件 时 编 吉 QE) 查看 WY) 收藏 六 人 ) 工具 了 和 攻 动 人 
宽 ”是 http:11127.0.0.Upipypgon2_phy 


这 是 我 输出 打印 的 第 一 个 文档 ， 


图 2-2 echo 输出 字符 


< 次 2.1.3 ) 程 序 的 注释 
在 PHP 的 语法 编写 过 程 中 可 以 使 用 3 种 风格 的 注释 方式 ， 


/* 第 1 种 PHP 注 释 适合 用 于 多 行 */ 

// 第 2 种 PHP 注 释 ”适合 用 于 单行 

# 第 3 种 PHP 注 释 ”适合 用 于 单行 

注释 和 C、C++、Shell 的 注释 风格 一 样 ， 以 /* 为 开始 ，*/ 为 结束 ， 如 下 : 
<?php 

/* 

注释 : 这 是 程序 的 注释 

该 段 程序 主要 用 于 文字 的 说 明 ...... 

a 

是 六 


单行 注释 (有 // 和 # 这 两 种 ): 


<?php 
echo "单行 "; // 输 出 单行 文字 
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echo "说 明 "; # 输 出 说 明文 字 


ea 


注意 一 下 ， 注 释 符 号 只 有 在 <?php ?> 里 面 才 会 起 到 应 有 的 效果 ， 如 图 2-3 所 示 。 


B pz003.php 
文件 EE) 编辑 E) 格式 @) 查看 WW 和 助 0D 
<?php 


(te 
?> 


图 2-3 注释 的 程序 


本 2.2 ”动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 只 使 用 echo0 函 数 命令 并 不 能 满足 实际 的 应 用 ， 如 需要 输 
出 随机 的 数字 、 控 制 字符 串 的 大 小 写 以 及 一 些 特殊 的 字符 处 理 等 常用 操作 ， 都 可 以 通过 调 
用 相应 的 函数 命令 加 以 实现 。 
-221 ) 随 机 耳 数 的 调用 

如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编 程 中 调用 相应 的 函 
数 还 是 比较 简单 的 ， 如 使 用 rand0) 函 数 来 产生 一 个 随机 数字 〈 范 围 是 0~10) : 

<?php 

echo rand(0,10); 

ee 

刷新 便 可 看 到 输出 结果 的 变化 ，rand 函 数 中 的 0 和 10 为 指定 给 rand 函 数 的 参数 。 前 面 的 
0 就 意味 着 最 小 可 能 出 现 的 数值 为 0，10 则 意味 着 最 大 可 能 出 现 的 数值 为 10， 很 多 函数 都 有 
必 选 或 是 可 选 的 参数 ， 如 图 2-4 所 示 为 随机 输出 的 数字 8。 


127.001 Si 


喜 看 如 中 二 天 由 工具 中 玫 物 虽 
写 碎 Hts:J1i27001/phe/zaiot pip 


8 


图 2-4 随机 函数 的 输出 


< 222 控制 字符 串 首尾 


使 用 trim0 函 数 可 以 返回 去 除 字符 串 string 首 尾 的 空白 字符 的 字符 串 。 


Ny 


Oa ss 得 实例 (第 2 版 ) 


语法 : 
string trim(string str); 


返回 值 : 字符 串 
函数 种 类 : 资料 处 理 
在 使 用 来 自 HTML 表 单 信息 之 前 ， 一 般 都 会 对 这 些 数据 做 一 些 整理 ， 举 例如 下 : 


<?php 

// 清 理 字符 串 中 开始 和 结束 位 置 的 多 余 空 格 
Sname = " 1235678 "; 

Sname = trim($name); 

echo $name; 

二 


运行 的 结果 可 以 将 前 后 的 空白 去 除 ， 如 图 2-5 所 示 。 


(Snttp://127.0.0. JMphp/pr005.php - Windows Internet Explorer 加 edl 


OO Er mn 司 史 四 加 


立 们 下 纺 气 于 | 查看 QD)。 收 套 到 旧 ， 工具 人 才 动 M0 
痪 | 阐 htte:1/ler 00 lple/ze0s pp 


1235678 


图 2-5 去 除 前 后 空白 的 输出 效果 


入 223 ) 格 式 化 输出 字符 


nl2br0 函 数 可 以 将 换行 字符 转换 成 HTML 换 行 的 <br> 指 令 。 
语法 : 
string nl2br(string string); 


返回 值 : 字符 串 

函数 种 类 : 资料 处 理 

举例 如 下 : 

<?php 

$str = "今天 的 是 周一 ,心情 也 很 好 
决定 去 学 校 游泳 场 ， 好 好 的 游 个 泳 。"; 
echo $str; 

echo "<br />"; 

echo nl2br ($str); 

2 


输出 的 结果 如 图 2-6 所 示 。 


.0. 1/php/p£006. php - Windows Internet Explorer 


ED» [ts /a.0.0. Ves pas 司 坷 区] 加 = 大 站 
文件 加 编 得 到 查看 久 收 训 天 由 工具 I) 帮助 00 


htto /27 0 0 lto/pains sip 


图 2-6 格式 化 输出 字符 的 结果 


pe 


< 224 打印 格式 化 输出 


PHP 支 持 print0 结 构 在 实现 echo 功 能 的 同时 能 返回 值 (true 或 false， 是 否 成 功 )， 使 用 


printfO 可 以 实现 更 复杂 的 格式 。 
语法 : 
int printf (string format, 
返回 值 : 整数 
函数 种 类 : 资料 处 理 
举例 如 下 : 


// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf ("数值 为 :%$s", Snum) ; 
echo "<br />™y 

// 转 换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf ("数值 为 :% .2f", $num); 
ocho "<br />"> 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf ("数值 为 :%$b", $num); 
echo "<br />"; 

// 打 印 % 符 号 

printf ("数值 为 :%%%s", $num); 
?> 


输出 的 结果 如 图 2-7 所 示 。 


mixed [args]...); 


(Ehttp://127.0. 0. 1/php/pe00T. php - Wintows Internet Explorer 


OO:E 
文件 于 ) 。 编 得 区 ) 
宽大 htp:11127.00.1/phe/?a07 pip 


1 001 


司 加 因 困 


查看 呈 。 路 蕙 天 直 ， 工具 四 帮助 0 


图 2-7 格式 化 输出 效果 


和 225 字母 大 小 写 转换 


字母 的 大 小 写 转换 在 PHP 网 页 转换 中 


经 党 


红 时 


使 用 到 , 涉及 的 常用 函数 命令 , 如 strtoupper() 


可 以 将 字符 串 转 换 成 大 写字 母 ， 将 每 个 单词 的 第 一 个 字母 变 大 写 可 以 使 用 ucwords0， 将 字 
符 串 的 第 一 个 字母 转 成 大 写 可 以 使 用 ucfirst)， 将 字符 串 转 换 成 小 写字 母 可 以 使 用 


strtolower()， 举 例如 下 : 


<?php 

$str = "I 1ike phpl"s 

// 将 字符 串 转 换 成 大 写字 母 

echo strtoupper ($str)."<br />" 
// 将 字符 串 转 换 成 小 写字 母 


echo strtolower ($str)."<br />" 
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Le 


i 


©) ; epip.. 
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让 

// 将 字符 串 的 第 一 个 字母 转 成 大 写 
echo ucfirst($str). "<br />"y 
// 将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords ($str); 

?> 


输出 的 结果 如 图 2-8 所 示 。 


LE http://127.0. 0. 1/php/pt008. php - Windows Interner Ezplorer 


0 加 nw mmoo wenonm 。 国 回 区] 网 
文件 对) 编 澡 革 ) 查看 WW) 收 阐 天 由 工具 G) 大 动 0D) 
寅 | 压 htp:1112700.1/phe/?a08 pip 


工 Like Php! 


图 2-8 字母 转换 大 小 写 
-入 2326 ) 特 殊 字符 的 处 理 


有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 枉 和 NULL 字 符 。 可 以 使 用 
addslashes() 函 数 和 stripslashes() 函 数 正确 处 理 这 些 字 符 ，PHP5 中 默认 是 开启 魔术 引号 的 
magic_quotes_gpc， 例 如 : 

<?php 

SEL "NS OA MT 

eeho $atr:. "<br /Zs 

echo addslashes ($str) ."<br />"; 


echo stripslashes ($str)."<br />"; 
So 


运行 结果 如 图 2-9 所 示 。 


图 2-9 ”处 理 特殊 的 字符 


> 2.3 表单 变量 的 应 用 


在 HTML 中 ， 表 单 拥有 一 个 特殊 功能 : 它们 支持 交互 作用 。 除 了 表单 之 外 ， 几 乎 所 有 
的 HTML 元 素 都 与 设计 以 及 展示 有 关 ， 只 要 愿意 就 可 将 内 容 传 送 给 用 户 ; 另 一 方面 ， 表 单 
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为 用 户 提供 了 将 信息 传送 回 Web 站 点 创建 者 和 管理 者 的 可 能 性 。 如 果 没有 表单 ， Web 就 是 
一 个 静态 的 网 页 图 片 。 对 于 PHP 的 动态 网 页 开发 ， 使 用 表单 变量 对 象 也 是 经 常 遇 到 的 ， 通 
常 主要 有 post0 和 getO 两 种 方法 ,这 和 其 他 动态 语言 开发 的 命令 是 一 样 的 ， 本 小 节 就 介绍 表 
单 变量 的 使 用 方法 。 


< POST 表单 变量 


POST 表单 变量 用 于 设置 处 理 表单 数据 的 类 型 ，POST 是 系统 的 默认 值 ， 表 示 将 数据 表 
单 的 数据 提交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假设 有 一 HTML 表 单 用 method="post" 
的 方式 传递 给 本 页 一 个 name="test" 的 文字 信息 ， 可 用 3 种 风格 来 显示 这 个 表单 变量 : 

<form action="" method="post" > 

<input type="text" name="test" /> 

<input type="submit" name=" 变 量 " value=" 提 交 " /> 

<?php 

Echo $test; // 简 短 格式 , 需 配 置 php.ini 中 的 默认 设置 

echo $_POST["test"]; // 中 等 格式 ,推荐 使 用 这 种 方式 

echo $HTTP_POST_VARS["test"]; // 宛 长 格式 

?> 

</form> 


运行 结果 如 图 2-10 所 示 。 
(Shttp://127.0.0. 1/php/pg010. php - Windows Internet Explorer 
GO- E 127.0.0.1 司 4x 加 
文件 于) ”编辑 到) 查看 收 硬 夹 ) 工具 CI) 帮助 0 
突入 http://127.0.0. 1/php/pal0 php 


莉 E 传 递 变量 


图 2-10 ”post 测试 效果 

GET 和 POST 的 主要 区 别 : 

(1) 数据 传递 的 方式 以 及 大 小 ; 

(2) GET 会 将 传递 的 数据 显示 在 URL 地 址 上 ，POST 则 不 会 ; 

(3) GET 传 递 数 据 有 限制 ， 一 般 大 量 数 据 都 得 使 用 POST 方法 。 
< 次 2.3.2 )GET 表 单 变 量 

GET 表 示 追 加 表单 的 值 到 URL 并 且 发 送 服务 器 请 求 ， 对 于 数据 量 比较 大 的 长 表单 最 好 
不 要 用 这 种 数据 处 理 方式 。 

假设 有 一 HTML 表 单 用 method="get" 的 方式 传递 给 本 页 一 个 name="test" 的 文字 信息 ， 
可 用 3 种 风格 来 显示 这 个 表单 变量 : 
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<form action="" method="get"” > 

<input type="text" name="test" /> 

<input type="submit" name=" 变 量 " value=" 提 交 " /> 
<?php 

Echo $test; // 简 短 格式 ,需要 配置 php .ini 中 的 默认 设置 
echo $_GET["test"]; // 中 等 格式 ,推荐 使 用 此 方法 

echo $HTTP_GET_VARS["test"]; // 宛 长 格式 

2 

</form> 


运行 结果 如 图 2-11 所 示 ， 在 IE 地 址 栏 里 显示 了 表单 变量 传递 的 值 。 


(Fhttp://127-0.0. phpypgoll phy?test=1234568%DIXEA%C 1XDF-%CC6 - Windors --。 因 | 加 | 网 


文件 中 纺 旬 四 区 工具 中 更 助 加 
襄 | 篇 httpii2T.0.0.1/pte/penll paprtest-l2365. 


123456 


图 2-11 get 测试 效果 
[5 鸭 连 接 字 符 中 


在 PHP 程 序 里 要 让 多 个 字符 串 进 行 连接 ， 要 用 到 一 个 (.)“ 点 ”号 ， 如 下 : 


<?php 

S$website = "www.sina"; 
echo S$website.".com"; 
> 


上 面 的 输出 结果 就 是 www.sina.com， 如 图 2-12 所 示 。 


(Shttp://127.0.0.1/php/pg012. php - Windows Internet Explorer 
GO mm x 可 
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图 2-12 连接 字符 串 输出 效果 


有 一 种 情况 ， 当 echo 后 面 使 用 的 是 () 双 引号 的 话 可 以 这 样 来 达到 和 上 面 同样 的 效果 : 


<?php 
Swebsite = "www.sina™; 


echo "$website.com";// 双 引号 里 的 变量 还 是 可 以 正常 显示 出 来 ， 并 和 一 般 的 字符 串 自 动 


a 


区 分 开 来 
?> 


但 如 果 是 单 引号 的 话 ， 就 会 将 里 面 的 内 容 完全 以 字符 串 形式 输出 给 浏览 


<?php 

Swebsite = "www.sina.com"; 
echo '$website.com'; 

> 


将 显示 $website.com。 


2 2.4 ”PHP 常量 和 变量 


常量 和 变量 是 编程 语言 的 最 基本 构成 要 素 ， 代 表 了 运算 中 所 需要 的 各 种 值 。 通 过 变量 
和 和 常量， 程序 才能 对 各 种 值 进行 访问 和 运算 。 学 习 变量 和 常量 是 编程 的 基础 。 常 量 和 变量 
的 功能 就 是 用 来 存储 数据 的 ， 但 区 别 在 于 常量 是 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 
符号 化 的 常数 ， 本 小 节 就 介绍 一 下 PHP 中 的 常量 和 变量 。 
< OPHP 中 的 常量 

常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处 理 不 需要 修改 的 值 时 ， 常 量 非 
常 有 用 ， 例 如 定义 圆周 率 PI。 常 量 一 旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ， 但 是 可 以 
在 程序 的 任何 地 方 访问 。 

在 PHP 中 使 用 define() 函 数 定义 常量 ， 函 数 第 1 个 参数 表示 常量 名 ， 第 2 个 参数 表示 常量 


的 值 。 
例如 ， 下 面 定义 一 个 名 为 HOST 的 常量 : 
<?php 
define ("HOST", "www.163.com"); /V/ 将 值 “www.163.com” 赋 于 常量 HOST 
echo HOST; // 输 出 HOST 常量 的 值 
?> 


运行 结果 如 图 2-13 所 示 。 
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图 2-13 定义 常量 输出 结果 


常量 默认 区 分 大 小 写 ， 按 照 惯例 ， 常 量 标识 符 总 是 大 写 。 常 量 名 和 其 他 任何 PHP 标 记 遵 循 相同 
的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 划 线 开始 ， 后 面 跟 任何 字母 、 数 字 或 下 划 线 。 


PHP 的 系统 常量 包括 5 个 魔术 常量 和 大 量 的 预定 义 常量 。 
魔术 常量 会 根据 它们 使 用 的 位 置 而 改变 ，PHP 提 供 的 5 个 魔术 常量 分 别 是 : 


去 源 汪 = 
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(1) _LINE_ : 表示 文件 中 的 当前 行 号 。 


(2) _FILE : 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文 
件 名 。 自 PHP 4.0.2 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 


个 相对 路 径 。 

(3) FUNCTION _”: 表示 函数 名 称 (PHP 4.3.0 新 加 ) 。 自 PHP5 起 ， 本 常量 返回 该 
函数 被 定义 时 的 名 字 《 区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

(4) CLASS_: 表示 类 的 名 称 (PHP 4.3.0 新 加 ) 。 自 PHP 5 起 ， 本 常量 返回 
定义 时 的 名 字 〔 区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

(5) _METHOD : 表示 类 的 方法 名 (PHP 5.0.0 新 加 ) 。 返 回 该 方法 被 定义 时 的 名 字 
〈 区 分 大 小 写 ) 。 

预定 义 常量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常量 两 种 ， 内 核 预 定义 常量 在 PHP 的 


内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常量 是 PHP 默认 定义 的 。 比 如 常 
用 的 E_ERROR、E_NOTICE、E_ALL 等 。 


< 2552)PHP 中 的 变量 


在 PHP 中 ,创建 一 个 变量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 号 
开头 ， 然 后 是 变量 名 。 如 果 在 声明 变量 时 ， 忘 记 变量 前 面 的 $ 符 号 ， 那 么 该 变量 将 无 效 。 
在 PHP 中 设置 变量 的 正确 方法 如 下 : 

$var_ name = value; 

在 PHP 中 ， 可 以 使 用 值 赋值 和 引用 赋值 这 两 种 方法 为 变量 赋值 。 值 赋值 是 直接 把 一 个 
数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 常量 的 变量 赋值 的 方法 ， 其 使 用 格式 如 下 
所 示 。 


类 


被 


<?php 

$name = "baidu"; // 有 效 变量 

SName = "website"; // 有 效 变 量 

echo "$name, $Name"; // 输 出 为 “baidu, website” 
$lwebsite = "www.baidu.com"; // 无 效 变量 ， 以 数字 开始 
$_lwebsite = "www.baidu.com"; // 有 效 变量 

?> 


从 上 述 代 码 中 可 以 看 到 ， 在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 根 
据 变 量 被 设置 的 方式 ，PHP 会 自动 把 变量 转换 为 正确 的 数据 类 型 。 

在 PHP 中 ， 变 量 的 命名 规则 有 如 下 几 点 : 

@ 变量 名 必须 以 字母 或 下 划 线 " "开头 。 

@ 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 划 线 。 

@ 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 划 线 进行 分 

隔 (例如 S$Smy_string) ， 或 者 以 大 写字 母 开头 (例如 SmyString) 。 
在 PHP 中 ， 还 支持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 : 
<?php 
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@ 0 R 
Swo = "baidu'7 // 为 变量 $wo 赋 值 
Sba = &$wos; // 取 变量 $ba 引 用 了 变量 $wo 的 值 
Sba = "Web site is $ba"; // 修 改变 量 $ba 的 值 
echo S$wo; // 结 果 为 “Web site is baidu” 
echo $ba; // 变 量 $ba 的 值 也 被 修改 ,结果 与 $ba 相 同 
?> 


从 这 里 可 以 看 出 ， 对 一 个 变量 值 的 修改 将 会 导致 对 另外 一 个 变量 值 的 修改 。 从 本 质 上 
讲 ， 变 量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修 
改 ， 修 改 的 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同 时 被 修改 的 结果 。 

PHP 提 供 了 大 量 的 预定 义 变量 ， 这 些 变量 在 任何 范围 内 都 会 自动 生效 ， 因 此 通常 也 被 
称 为 自动 全 局 变量 (autoglobals ) 或 者 超 全 局 变量 (superglobals，PHP 中 没有 用 户 自 定义 
超 全 局 变量 的 机 制 ) 。 在 PHP 4.1.0 之 前 , 如 使 用 超 全 局 变量 ,人们 要 么 依赖 register_globals， 
要 么 就 是 长 长 的 预定 义 PHP 数组 (SHTTP_*_VARS) 。 自 PHP 5 起 ， 长 格式 的 PHP 预 
定义 变量 可 以 通过 设置 register_long_arrays 来 屏蔽 。 

常用 的 超 全 局 变量 如 下 。 


@ $GLOBALS: 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 。 该 数组 
的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 SGLOBALS 数 组 。 

@ $_ SERVER: 变量 由 Web 服 务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 。 类 似 
于 旧 数 组 SHTTP_SERVER_VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_GET: 经 由 URL 请 求 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 SHTTP_GET_VARS ( 依 
然 有 效 ， 但 反对 使 用 ) 。 

@ $ POST: 经 由 HTTP POST 方法 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
$SHTTP_POST_VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $ COOKIE: 经 由 HTTP Cookies 方 法 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
$SHTTP_COOKIE_VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_FILES: 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
$SHTTP_POST_FILES 数 组 (依然 有 效 ， 但 反对 使 用 ) 。 

@@ $_ENV: 执行 环境 提交 至 脚本 的 变量 。 类似 于 旧 数 组 SHTTP_ENV_VARS (依然 有 
效 ， 但 反对 使 用 ) 。 

@ $ REQUEST: 经 由 GET，POST 和 和 COOKIE 机制 提 交 至 脚本 的 变量 ， 因 此 该 数组 并 
不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 存在 与 否 以 及 变量 的 顺序 均 按照 php.ini 
中 的 variables_order 配 置 指示 来 定义 。 此 数组 在 PHP 4.1.0 之 前 没有 直接 对 应 的 版 
本 。 

@@ $_SESSION: 当前 注册 给 脚本 会 话 的 变量 。 类 似 于 旧 数 组 SHTTP_SESSION_VARS 
(依然 有 效 ， 但 反对 使 用 ) 。 


-和 243 )PHP 数 据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 
处 理 的 员工 工资 额 、 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 贴 数 等 等 ， 所 有 这 些 都 是 
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数据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 节省 有 限 的 内 容 资 源 ， 需 要 对 数据 进行 
分 类 。PHP 支 持 7 种 原始 类 型 ， 分 别 是 : boolean (布尔 型 true/false) 、integer (整数 类 型 ) 、 
float 〈 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 ) 、string (字符 串 类 型 )、array〈( 数 组 同 
一 变量 保存 同类 型 的 多 条 数据 ) 、object (对 象 ) 和 特殊 类 型 (resource 资 源 和 NULL 未 设 
定 ) 。 


下 面 介绍 这 些 数据 类 型 。 


1. 布尔 型 (boolean) 

布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 
用 关键 字 True 或 False， 并 且 True 或 False 不 区 分 大 小 写 。 例 如 : 

S$pay = true; // 给 变量 Spay 赋 值 为 true 


某 些 运算 通常 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 (==) 来 比较 
两 个 运算 数 ， 如 果 相等 ， 则 返回 True， 否 则 返回 False。 代 码 如 下 : 

if ($A == $B) { 

echo "$A 与 $B 相等 "; 

} 

对 于 如 下 的 代码 

if ($pay == TRUE) { 

echo "已 付 "; 

} 

可 以 使 用 下 面 的 代码 代替 : 

if ($pay) { 

echo ”已 付 ”7 

} 

转换 成 布尔 型 用 bool 或 者 boolean 来 强制 转换 ， 但 是 很 多 情况 下 不 需要 用 强制 转换 ， 因 
为 当 运 算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 该 值 会 被 自动 转换 。 

当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False: 


@ 布尔 值 False。 

整 型 值 0 ( 零 ) 。 

浮 点 型 值 0.0 ( 零 ) 。 

空白 字符 串 和 字符 串 "0"。 

没有 成 员 变量 的 数组 。 

没有 单元 的 对 象 ( 仅 适用 于 PHP 4) 。 
特殊 类 型 NULL (包括 尚未 设 定 的 变量 ) 。 


所 有 其 他 值 都 被 认为 是 True〈 包 括 任何 资源 ) 。 
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as， 
@ *@ 
2. 整 型 (integer) 

一 个 整数 是 集合 Z={.…, -2, -1, 0, 1, 2, …} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 进 
制 或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 〈- 或 者 +) 。 如 果 用 八进制 ， 数 字 前 必须 加 上 
0( 零 ) ， 用 十 六 进 制 数字 前 必须 加 上 0x。PHP 不 支持 无 符号 整数 。 整 型 数 的 字 长 和 平台 有 
关 ， 通常 最 大 值 大 约 是 20 亿 “(32 位 有 符号 ) 。 如 果 给 定 的 一 个 数 超出 了 整 型 的 范围 ， 将 会 
被 解释 为 浮 点 型 ， 同 样 如 果 执 行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强 制 转换 。 不 过 大 多 数 情况 下 都 不 需要 强制 转 
换 ， 因 为 当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 值 会 自动 转换 。 还 可 以 通过 函 
数 intval0 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 会 转换 为 0，True 将 会 转换 为 1。 当 从 浮 点 数 转换 成 整数 时 ， 
数字 将 被 取 整 (丢弃 小 数位 ，。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 
足够 的 精度 使 浮 点 数 给 出 一 个 确切 的 整数 结果 。 


3. 浮 点 型 (float) 
浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 


<?php 
$a =, TL.2347 
$b = 1.2e3; 
$c = 7E-10; 
?> 


浮 点 数 的 字 长 和 平台 相关 ， 通 常 最 大 值 是 1.8e+308 并 具有 14 位 十 进 制 数字 的 精度 。 


4. 字符 串 〈string) 

字符 串 是 由 引号 括 起 来 的 一 些 字符 ， 常 用 来 表示 文件 名 、 显 示 消 息 、 输 入 提示 符 等 。 
字符 串 是 一 系列 字符 ， 字 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引 号 、 双 引号 或 定 界 符 3 
种 方法 定义 ， 下 面 分 别 介绍 这 3 种 方法 。 

(1) 单 引号 

指定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引 号 〈") 括 起 来 。 例 如 : 

<?PhP 

echo 'Hello World '; // 输出 为 : Hello World 

2 

如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 和 很 多 其 他 语言 一 样 ， 需 要 用 反 斜 
线 (\) 转 义 。 例 如 : 


<?php 
echo 'I\'m Tom'; // 输出 为 : I’m Tom 
?> 


如 果 在 单 引 号 之 前 或 字符 串 结尾 需要 出 现 一 个 反 斜 线 〈(\) ， 需 要 用 两 个 反 斜 线 (\) 
表示 。 例 如 : 


ey 
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<?php 
echo 'Path is c:\windows\system\\'; // 输出 为 : Path is cc:\windows\system\ 
?> 


对 于 单 引 号 〈") 括 起 字符 串 ，PHP 只 懂得 单 引 号 和 反 斜 线 的 转 义 序列 。 如 果 试 图 转 
义 任何 其 他 字符 ， 反 伴 线 本 身 也 会 被 显示 出 来 。 另外 ， 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重 
要 的 一 点 就 是 ， 单 引号 字符 串 中 出 现 的 变量 不 会 被 解析 。 

(2) 双 引 号 

如 果 用 双 引 号 〈") 括 起 字符 串 ，PHP 懂 得 更 多 特殊 字符 的 转 义 序列 〈 见 表 2-1) 。 

表 2-1 转 义 字符 
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如 果 试 图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 同 样 也 会 被 显示 出 来 。 双 引号 字符 串 最 重要 
的 一 点 是 能 够 解析 其 中 的 变量 。 

Ee 定 界 符 

一 种 给 字符 串 定 界 的 方法 就 是 使 用 定 界 符 语法 (<<<) 。 应 该 在 <<< 之 后 提供 一 个 标 

pw 接着 是 字符 串 ， 然 后 是 同样 的 标识 符 结束 字符 串 。 例 如 : 

<?php 

// 输出 为 : Hello World 

echo <<<abc 

Hello World 


abc; 
?> 


在 此 段 代 码 中 ,标识 符 命名 为 abc。 结 束 标识 符 必须 从 行 的 第 一 列 开始 。 标识 符 所 遵循 
的 命名 规则 是 : 只 能 包含 字母 数字 下 划 线 ， 而 且 必须 以 下 划 线 或 非 数字 字符 开始 。 

定 界 符 文本 表现 的 就 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 着 在 定 界 符 文本 
中 不 需要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 被 解析 。 在 以 上 的 3 
种 定义 字符 串 的 方法 中 ， 若 使 用 双 引 号 或 者 定 界 符 定义 字符 串 ， 其 中 的 变量 会 被 解析 。 


-58- 


5. 数组 array 

PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映 射 到 key 的 类 型 。 新 建 一 个 数 
组 使 用 array0 语 言 结构 ， 它 接受 一 定数 量 用 逗号 分 隔 的 key => value 参 数 对 。 

语法 如 下 : 


array( [ key => ] value , ... ) 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数组 ， 
则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 

<?php 

$edName = array(0 =>"id", 1=>"username", 2=>"password"); 

echo " 列 名 是 SedName [0] $edName[1], $edName[2]"; 

?> 

此 段 代码 的 输出 为 : 列 名 是 id、username、password。 

如 果 省 略 了 键 key， 会 自动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 

<?php 

$edName = array("id", "username", "password"); 

echo " 列 名 是 SedName [0], $edName[1], $edName[2]"; 


此 段 代 码 的 输出 仍 为 : 列 名 是 id、username、password。 

如 果 key 是 整数 , 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 果 指 定 的 键 已 经 
有 了 值 ， 则 新 值 会 覆盖 旧 值 。 再 次 改写 上 面 的 代码 为 : 

<?php 

$edName = array(1=>"id", "username", "password"); 

echo " 列 名 是 $SedName [1], $edName[2], $edName[3]"; 

2 

此 段 代 码 的 输出 仍 为 : 列 名 是 id、username、password。 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 空 的 方 括号 〈0D) 。 

语法 如 下 : 

$arrayName [key] = value; 

$arrayName [] = value; 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 


<?PhP 

SedName[0]= "id"; 

SedName [1]= "username™"; 

SedName[2]= "password"; 

echo " 列 名 是 SedName [0] $edName[1], $edName[2]"; 
?> 


此 段 代码 的 输出 仍 为 : 列 名 是 id、username、password。 
如 果 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 
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果 当 前 还 没有 整数 索引 ， 则 键 将 为 0。 如 果 指 定 的 键 已 经 有 值 了 ， 该 值 将 被 覆盖 。 
对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 字 符 串 和 资源 等 ， 如 果 将 一 个 值 转换 为 数组 ， 
将 得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0) ， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 
象 转换 成 一 个 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 《成员 变量 ) ， 其 键 为 成 员 变 量 
。 如 果 将 一 个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 


6. 对 象 (object) 
使 用 class 定 义 一 个 类 ， 然 后 使 用 new 类 名 构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数 
据 类 型 将 在 后 面 的 实例 应 用 中 具体 进行 解析 。 


7. 其 他 数据 类 型 
除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 。 


(1) 资源 

资源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 引用 。 可 
以 保存 打开 文件 、 数 据 库 连 接 、 图 形 画 布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 转换 为 
资源 。 资 源 大 部 分 可 以 被 系统 自动 回收 。 


(2) NULL 

NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 特 殊 的 NULL 值 表示 一 个 变 
量 没 有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL: 

@ 被 赋值 为 NULL。 

@ 尚未 被 赋值 。 

@ 被 unset()。 


例如 : 


<?php 

Sphps= 

if (isset ($a)) 

echo “[1] is NULL<br>" ; 
$php = 0; 

if (isset ($a)) 

echo “[2] is NULL<br>” ; 
$php = NU117 

if (isset ($a)) 

echo “[3] is NULL<br>” ; 
$php = FALSE; 

if (isset ($a)) 

echo “[4] is NULL<br>” ; 
> 


结果 是 什么 ? 
在 三 种 情况 下 变量 被 认为 是 空 值 : 


-0= 


@ 变量 没有 被 赋值 ; 
@ 变量 被 赋值 为 null，0，FALSE 或 者 空 字符 串 ; 
@ 变量 在 非 空 值 的 情况 下 ， 被 unsetO 函 数 释 放 。 
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在 PHP 中 若 要 进行 数据 类 型 的 转换 ， 就 要 在 转换 的 变量 之 前 加 上 用 括号 括 起 来 的 目标 
类 型 。 在 变量 定义 中 不 需要 显示 的 类 型 定义 是 根据 使 用 该 变量 的 上 下 文 所 决定 的 。 
例如 通过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 另外 一 种 类 型 : 


<?php 

$num = 123; // 当 前 是 整数 类 型 

$float = (float)$num; //$num" 临 时 性 “地 转换 成 了 浮 点 型 ，$f1oat 变 量 所 携带 的 数 
据 类 型 就 为 浮 点 型 

echo gettype ($num) ."<br />";// 使 用 gettype (mixed var) 函数 来 获取 变量 类 型 

echo gettype ($float) 

本 


运行 结果 如 图 2-14 所 示 。 
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integer 


double 


有 图 2-14 数据 类 型 的 转换 
妨碍 局- 
如 要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 得 使 用 settype(mixed var,string type) 函 数 。 
允许 的 强制 转换 有 : 

@ int、integer: 转换 成 整 型 。 

@ bool、boolean: 转换 成 布尔 型 。 

@ float、double、real: 转换 成 浮 点 型 。 
@ string: 转换 成 字符 串 。 

@ array: 转换 成 数组 。 

@ object: 转换 成 对 象 。 
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5 PHP 运算 符 


学 过 其 他 语言 的 读者 ， 对 于 运算 符 应 该 不 会 陌生 ， 运 算 符 可 以 用 来 处 理 数 字 、 字 符 串 
及 其 他 的 比较 运算 和 风 辑 运算 等 。 在 PHP 中 , 运算 符 两 侧 的 操作 数 会 自动 地 进行 类 型 转换 ， 


al 


二 和 下 < 


会 
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这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 三 种 类 型 的 运算 符 , 它们 分 别 是 : 


@ 一 元 运算 符 ， 只 运算 一 个 值 ， 例 如 : ! ( 取 反 运算 符 ) 或 ++ (加 一 运算 符 ) 。 
@ 二 元 运算 符 ，PHP 支持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 : S$a+ $b。 
@ 三 元 运算 符 ，( 即 ? : ) 它 被 用 来 根据 一 个 表达 式 的 值 在 另 两 个 表达 式 中 选择 一 


个 ， 而 不 是 用 来 在 两 个 语句 或 者 程序 路 线 中 选择 。 


PHP 中 常用 运算 符 有 算术 运算 符 、 赋 值 运算 符 、 比 较 运算 符 、 三 元 运算 符 、 错 误 控 制 
运算 符 、 逻 辑 运算 符 、 字 符 串 运 算 符 、 数 组 运算 符 等 。 本 节 将 主要 介绍 这 些 常 用 的 运算 符 ， 
以 及 运算 符 的 优先 级 。 


<- 251 ) 算 术 运 算 符 


算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 、 也 最 常用 的 符号 ， 尤 其 是 数字 的 
处 理 ， 几 乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 所 示 。 


表 2-2 算术 运算 符 


除 号 (/) 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 (或 由 字符 串 转 换 成 的 整数 ) 也 是 这 样 。 
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赋值 运算 符 (Assignment Operator) 把 表达 式 右边 的 值 赋 给 左边 变量 或 常量 。 基 本 的 
赋值 运算 符 是 =， 它 意味 着 把 右边 表达 式 的 值 赋 给 左边 的 运算 数 。PHP 中 的 赋值 运算 符 见 
表 2-3 所 示 。 


表 2-3 赋值 运算 符 


将 右边 的 值 连 到 左边 
将 右边 的 值 加 到 左边 ， 即 Sa = Sa+ $b 
将 右边 的 值 减 到 左边 ， 即 Sa = $a- Sb 


= 


将 左边 的 值 乘 以 右边 ， 即 $a = $a * $b 


将 左边 的 值 除 以 右边 ， 即 $a = $a / $b 
将 左边 的 值 除 对 右边 取 余 数 ， 即 $a = $a % $b 
将 右边 的 字 串 加 到 左边 ， 即 $a = $a . $b 


在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运算 符 的 “组 和 运算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结果 赋 给 它 ， 例 如 : 

<?php 

$a ="baidu"; 

$b =".com"; 

echo $a .= $b; 

?> 


运行 结果 如 图 2-15 所 示 。 
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图 2-15 赋值 运算 字符 串 结果 
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比较 操作 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 ， 根 据 结果 来 返回 true 或 false。 比 
较 运 算 符 ， 允 许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 


表 2-4 ”比较 运算 符 


True， 如 果 $a 等 于 Sb 
True， 如 果 Sa 等 于 $b， 并 且 它们 的 类 型 也 相同 


True， 如 果 $a 不 恒 等 于 Sb 
True， 如 果 $a 不 等 于 Sb 


True， 如 果 $a 不 等 于 Sb， 或 者 它们 的 类 型 不 同 (PHP 4 引进 ) 
True， 如 果 $a 严格 小 于 $b 
True， 如 果 $a 严格 大 于 $b 


True， 如 果 $a 小 于 或 者 等 于 Sb 


大 于 等 于 “| True， 如 果 Sa 大 于 或 者 等 于 Sb 


< 直入 = 
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三 元 运算 符 是 ?:， 三 元 运算 符 的 功能 和 if...else 语 句 很 相似 ， 语 法 如 下 : 
(expr1) ? (expr2) : (expr3) 


首先 对 exprl 求 值 ， 若 结果 为 Trne， 则 表达 式 (expr1) ? (expr2) : (expr3) 的 值 为 expr2， 否 
则 其 值 为 expr3。 例 如 : 
<?php 


$action = (empty($ POST['action'])) ? 'default' : $ POST['action']; 
?> 


首先 判断 S$_POST['action"] 变 量 是 否 为 空 值 ， 若 是 则 给 $action 赋 值 为 default， 否 则 将 
$_POST['action"] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 : 
<?php 
if (empty($ POST['action'])) { 
$action = 'default'; 
} else { 
$action = $_ POST['action']; 
} 
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抑制 操作 符 可 在 任何 表达 式 前 使 用 ，PHP 支 持 一 个 错误 抑制 运算 符 @。 当 将 其 放置 在 
一 个 PHP 表 达 式 之 前 ， 该 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 掉 。@ 运 算 符 只 对 表达 
式 有 效 。 

那么 ， 何 时 使 用 此 运算 符 呢 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 就 能 在 它 
前 面 加 上 @ 运 算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 和 includeO0 调 用 、 常 量 之 前 。 不 能 把 
它 放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 〈 例 如 if 和 foreach 等 ) 。 

比如 下 面 的 代码 : 

<?php 


$Conn= mysql_connect ("localhost","username", "pwd"); 
4£f  ( SConn) 
echo "连接 成 功 ! "; 


else 


echo "连接 失败 ! "; 


?> 


如 果 mysql_connectO 连 接 失 败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程序 
如 果 不 想 显示 系统 的 错误 提示 , 并 希望 失败 后 立即 结束 程序 , 则 可 以 改写 上 面 的 代码 如 下 : 


<?php 

SConn = @mysql _ connect ("localhost","username","pwd") or die ("连接 数 
据 库 服务 器 出 错 ") ; 

2 


在 mysql_connect0 函 数 前 加 上 @ 运 算 符 来 屏蔽 系统 的 错误 提示 ， 同 时 使 用 die0 函 数 给 
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出 自 定 义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 
< 2.5.6_) 逻 辑 运算 符 

PHP 的 逻辑 运算 符 〈Logical Operators) 通常 用 来 测试 真 假 值 ， 常 用 的 逻辑 运算 符 如 
表 2-5 所 示 。 


表 2-5 ”逻辑 运算 符 
例子 意义 


如 果 $a 或 Sb 任 一 为 True 
| Sa xor $b 如 果 $a 或 Sb 任 一 为 True， 但 不 同时 是 
Not 如 果 $a 不 为 True 
[Lo sl | jos 或 sre | 


“与 ”和 “或 ”有 两 种 不 同形 式 运 算 符 ， 它 们 运算 的 优先 级 不 同 ，&&& 比 | 优先 级 高 。 
多 2.5.7 ) 字 符 串 运算 符 
字符 串 运 算 符 (String Operator) 有 两 个 字符 串 运算 符 。 第 一 个 是 连接 运算 符 (.) ， 


它 返 回 其 左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 符 (.=) ， 它 将 右边 参数 附加 
到 左边 的 参数 后 。 


例如 : 

<?php 

$a 本 "你 好 "; 

$a = $a . "朋友 !"; // 此 时 $a 是 "你 好 朋友 !" 
Sb = "你 好 


$b .= "朋友 !"; // 此 时 $b 是 "你 好 朋友 !" 


2 
PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 
表 2-6 ”数组 运算 符 


符号 名 称 例 子 意义 
Sa 和 Sb 的 联合 ， 返 回 包含 了 Sa 和 Sb 中 所 有 元 素 的 数组 
| 一。 [ssp | 条 sonsb 具 有 相同 的 元 就 返 加 wue 
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联合 运算 符 (+) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 是 重复 的 键 值 不 会 被 覆盖 。 
下 面 通 过 一 个 实例 来 看 一 下 如 何 用 + 运算 符 联合 两 个 数组 : 


<?php 

$a = array ("1"=>"Nol1", 
"2"=>"No2", 
m3"=>"NoSn", 


man=>"No4"); 


$b = array ("3"=>"No3", 
"4"=>"No4", 
"5"=>"NoS", 
"6"=>"No6"); 

$c = $a+Sb7 

print_r ($c) ; // 联 合 两 数组 
echo "<br />"; 

if ($a==$b) 

echo "等 价 "; 

else 

echo "不 等 价 "; 


?> 
可 以 看 到 ， 在 联合 之 后 的 数组 结果 如 图 2-16 所 示 。 
Chttp://127-0.0. 1/php/pe017. php 
GO-E 
文件 中 多 可 如 查看 名” 收 戈 天 ) 工具 GD 帮助 
会 外 hMtp://127.0.0. Uphp/paiT php 


Array ( [1] => Nol [2] => No2 [3] => No3 [4] => Nod [5] => No5 [6] => No6 ) 
不 等 价 


图 2-16 联合 数组 标 例 


259 ) 运 算 符 的 优先 级 

运算 符 优先 级 指定 了 两 个 表达 式 绑 定 得 有 多 “紧密 ”。 例如， 表达 式 1 + 2 * 3 的 结果 
为 7 是 因为 乘 号 〈*) 的 优先 级 比 加 号 (+) 高 。 必 要 时 可 以 用 括号 来 强制 改变 优先 级 。 例 
如 (1+2)* 3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 优 先 级 相同 ， 则 使 
用 从 左 到 右 的 左 结合 顺序 〈 左 结合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 相反 ) 。 

表 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具有 相同 优先 级 ， 
此 时 它们 的 结合 方向 决定 求 值 顺序 。 
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表 2-7 ”运算 符 优先 级 


Er TT 
TTY CC 

| 

ET 7 | 
人 em | 
en | 
二 Te | 
和 am | 
二 am | 
Er CP E 
i 

FF 
人 和 am | 
本 


下 面 结合 前 面 所 用 到 的 操作 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 : 


<?php 

// 定 义 几 个 常量 ， 最 好 是 使 用 大 写 
define ("PEN"，20); // 钢 笔 为 20 元 
define("RULE",10); // 尺 子 为 10 元 


时 | 时 | 时 | 时 | 时 | 时 


时 


上 


时 


时 


$pen_num = 10; //10 只 钢笔 
Sruler_num =20; //20 把 尺子 


$total price = $pen num * PEN 
+ $ruler num * RULE; 


$total price = number format ($total price); 


echo "购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ".$total price." 元 "; 


ES 


a 


(Fhttp://127- 0.0. 1/phpypg018- php - Windovs Internet Ezplorer 


OO Er /mo 可 x| 哺 于 


文件 四， 编 各 加 查看 四。 中 春天 上 工具 CD) 条 助 思 
窜 | 息 Mt//i27 0.0. Myptpjraia yhp 


购买 10 只 钢笔 和 20 把 尺子 一 共 夏 花 400 元 


图 2-17 综合 运算 符 的 应 用 
2 2.6 ”PHP 表 达 式 


在 PHP 程 序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 作 表达 式 。 也 就 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 并 具有 返回 值 。 一 个 表达 式 通常 由 两 部 分 构成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 本 节 介 绍 常用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语 句 、 循 
环 语 句 ， 以 及 require 和 include 语 名 等。 


< 2671) 条 件 语句 


条 件 语 句 在 PHP 中 非常 普遍 ， 是 PHP 程 序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
端 获 得 一 个 参数 ， 根 据 传 入 的 参数 值 ， 做 出 不 同 的 响应 。 在 PHP 中 条 件 语句 分 别 为 f 语 句 、 
if-else 语 句 、if-elseif-else 语 句 和 switch 语 句 。 


下 面 我 们 分 别 介绍 这 3 种 形式 的 条 件 语 句 : 


1. 话语 句 
让 语句 是 许多 高 级 语言 中 重要 的 控制 语句 ， 使 用 进 看 句 可 以 按照 条 件 判断 来 执行 语句 ， 
增强 了 程序 的 可 控制 性 。if 语 句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 


JE ( expr ) 
statement 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement， 如 果 值 为 False， 将 忽略 
statement 。 


图 2-18 所 示 为 上 述 语法 格式 在 执行 时 的 逻辑 结构 。 


Start True ( 真 ) End 
程序 片段 程序 结束 


False ( 假 ) 


图 2-18 站 语句 逻辑 示意 图 


例如 : 
<?php 
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$Numl=10; 

SNum2=97 

if($Num1>$Num2) 

echo "$Numl 大 于 $SNum2"; 
?> 


上 述 实 例 演示 了 if 语 句 的 逻辑 结构 ， 会 在 变量 SNum1 大 于 SNum2 时 输出 “$Numl 大 于 
SNum2”。 


t 


2. if-else 语句 


条 件 语 句 的 第 二 种 形式 是 if..else， 除 了 if 语 句 之 外 ， 还 加 上 了 else 语 句 ，else 语 句 可 以 
在 if 语句 中 表达 式 的 值 为 False 时 执行 ， 语 法 如 下 : 

4 (oxpe  ) 

statement1 

else 

statement2 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement1; 如 果 值 为 False， 则 执行 
statement2。 


这 种 情况 的 执行 逻辑 结构 如 图 2-19 所 示 。 


程序 片段 2 
False( 假 》 


图 2-19 if-else 语句 逻辑 示意 图 
例如 以 下 代码 ， 在 $a 大 于 $b 时 显示 “a 大 于 b”， 反 之 则 显示 “a 不 大 于 b”: 
<?php 
if ($a > $b) 


echo "a 大 于 b"; 
else 


echo "a 不 大 于 b"; 


Rs 


else 语 句 仅 在 站 以 及 if-else( 如果 有 的 话 ) 语句 中 的 表达 式 值 为 False 时 执行 ， 它 不 可 以 单独 使 用 。 


3. if-elseif-else 语句 


条 件 语句 的 第 三 种 形式 是 让 ..elseif..else，elseif 是 if 和 else 的 组 合 。 和 else 一 样 ， 它 延伸 


a 


沽 
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了 if 语 句 ， 可 以 在 原来 的 if 表 达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 不 一 样 的 是 ， 它 仅 
在 elseif 的 条 件 表 达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 

if ( expl ) 

statement1 

elseif ( exp2 ) 

statement2 

elseif ( exp3 ) 


SEE 

statementn 

首先 对 exprl 求 值 , 如 果 exprl 的 值 为 True, 则 执行 statementl, 如 果 值 为 False, 则 对 expr2 
求 值 ， 如果 expr2 的 值 为 True， 则 执行 statement2， 如 果 值 为 False， 则 对 expr3 求 值 ， 依 次 
类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False， 则 执行 statementn 。 

这 种 情况 的 执行 逻辑 结构 ， 如 图 2-20 所 示 。 


程序 结束 


图 2-20 ifelseifelse 语句 逻辑 示意 图 

例如 以 下 代码 将 根据 条 件 分 别 显 示 “a 大 于 b”、“a 等 于 b” 和 “a 小 于 b”: 
<?php 
if ($a > $b) { 

seho "a 大 于 "Db"y 
Felseif (Sa == $b) 

echo "a 等 于 b"; 
} else { 

echo "a 小 于 b"; 


BB 


elseif 也 可 以 写成 else if (两 个 单词 )， 它 和 elseif (一 个 单词 ) 的 行为 完全 一 样 。 


= 


4. switch 语句 


使 用 switch 语 句 可 以 避免 大 量 地 使 用 if-else 控 制 语 句 。switch 语 句 首先 根据 变量 值得 到 
一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执 行 语句 。switch 语 句 计 算 expression 的 值 ， 然 后 和 
case 后 的 值 进行 比较 ， 跳 转 到 第 一 个 匹配 的 case 语 句 开始 执行 后 面 的 语句 ， 如 果 没 有 case 
匹配 就 跳 转 到 default 语 句 执行 ， 如 果 没 有 default 语 句 ， 则 退出 。 到 找到 匹配 项 的 时 候 ， 解 
析 器 会 一 直 运 行 直到 switch 结 尾 或 者 遇见 break 语 句 。case 语 句 可 以 使 用 空 语句 。 
PHP 提 供 了 分 支 (switch) 语句 来 直接 处 理 多 分 支 选择 ， 语 法 如 下 : 
Switch (expr) { 
case constant-expression: 
statement 
jump-statement 
[default: 
statement 
jump-statement 


] 
} 


其 中 的 常量 表达 式 (constant-expression) 可 以 是 任何 求 值 类 型 的 表达 式 ， 即 整 型 或 浮 
点 数 以 及 字符 串 。 
其 逻辑 结构 如 图 2-21 所 示 。 


Start Tme ( 真 ) 


False| ( 假 ) 


End 


程序 片段 1 程序 结束 


! 
False! ( 假 ) 


图 2-21 switch 语句 逻辑 结构 
下 面 一 段 代 码 是 switch 语 句 的 简单 应 用 : 


<?php 
switch ($a) { 
case 0: 
echo "a l= OF 
break; 
case 1: 


二 这 再 二 
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echo "a = 1"» 
break; 
case 2: 
echo "a = 2"; 
break; 
} 
> 
switch 语 名 一 行 接 一 行 地 执行 《实际 上 是 语句 接 语句 ) 。 开 始 时 没有 代码 被 执行 ， 仅 
当 一 个 case 语 句 中 的 值 和 switch 表 达 式 的 值 匹 配 时 PHP 才 开始 执行 语句 , 直到 switch 的 程序 
段 结束 或 者 遇 到 第 一 个 break 语 名 为止。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ，PHP 将 
继续 执行 下 一 个 case 中 的 语句 段 。 例 如 
<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
case 1: 
echo "a = 1"; 
case 2: 
echo "a = 2"7 
} 
?> 
i 于 0，PHP 将 执行 所 有 的 输出 语句 ， 如 果 $a 等 于 1，PHP 将 执行 后 面 两 
条 输出 语句 ， 只 有 当 $a 等 于 2 时 才 会 得 到 结果 : a = 
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poli ney 让 程序 重复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 
结果 为 假 时 ， 结 束 执行 语句 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循 环 、do-while 循 环 、 
pi 


1. while 循环 语句 

While 循 环 语句 的 。 格 式 是 : 

while (expr) 

statement 

只 要 expr 的 值 为 True 就 重复 执行 嵌 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 值 。 
有 时 候 如 果 while 表 达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 说 ， 
在 代码 片段 中 会 存在 改变 表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循 环 。 图 2-22 所 示 为 该 语句 
的 逻辑 结构 。 


全 


Start 
程序 运行 
False( 假 ) 
图 2-22 while 语句 逻辑 示意 图 
例如 
<?php 
$a= 1; 


while ($a <= 5) { 
echo $a++; // 从 1 到 5 依次 输出 
} 


二 


执行 该 程序 后 会 输出 从 1 到 5 的 数字 。 


2. do-while 循环 语句 

do-while 语 句 和 while 语 句 基本 一 样 。 不 同 之 处 在 于 while 语 句 在 “{}” 内 的 语句 执行 之 
前 检查 条 件 是 否 满足 ， 而 do-while 语 句 则 先 执 行 “{}” 内 的 语句 ， 然 后 再 判断 条 件 是 否 满 
足 ， 如 果 满 足 就 继续 循环 ， 不 满足 就 跳出 循环 。 


do 
statement 
while (expr) 


图 2-23 所 示 为 该 语句 的 逻辑 结构 。 


Start 


图 2-23 ”do-while 语句 逻辑 示意 图 


例如 : 


<?php 

$a = 0; 

do 1{ 

echo $a; 

} 
while ($a > 0); 
2 


以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检查 表达 式 的 真 值 时 ， 其 值 为 


Ss 
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False ($a 不 大 于 0) 而 导致 循环 终止 。 


3. for 循环 语句 

for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循 环 的 语法 是 : 

for (exprl; expr2; expr3) 

statement 

其 中 ， 第 1 个 exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr2 在 每 次 循环 开始 前 求 值 。 
如 果 值 为 True， 则 继续 循环 ， 执 行 圣 套 的 循环 语句 。 如 果 值 为 False， 则 终止 循环 。 第 3 个 
expr3 在 每 次 循环 之 后 被 求 值 (执行 ) 。 每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 
循环 下 去 〈 和 C 一 样 ，PHP 认 为 其 值 为 True) 。 因 为 有 时 候 会 希望 用 break 语 句 来 结束 循环 
而 不 是 用 for 的 表达 式 真 值 判 断 。 

图 2-24 所 示 为 该 语句 的 逻辑 结构 , 表达 式 2 为 true 则 执 进程 序 片 段 , 其 值 在 表达 式 1 中 初 


始 化 ， 在 表达 式 3 中 进行 修改 。 


False( 假 ) 


图 2-24 for 语句 逻辑 示意 图 
下 面 通过 使 用 for 循 环 语句 输出 九 九 乘法 表 : 
<?php 
for ($i=1; $i<10;$i++) 
{ 
for ($j=1;$j<10;$j++) 
{ 
echo "$i*$j=" .$i*$j; 
echo "gnbsp"; 
} 
echo "<br/>"; 
} 
2 


4. foreach 循环 语句 
foreach 语句 是 一 种 遍历 数组 的 简便 方法 。foreach 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 


他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。 有 两 种 语法 ， 第 二 种 比较 次 要 ， 但 却 
是 第 一 种 的 有 用 的 扩展 。 


和 


第 一 种 格式 : 
foreach (array expression as $value) 
statement 


第 二 种 格式 : 
foreach (array expression as $key => $value) 
statement 


第 一 种 格式 遍历 给 定 的 array_expression 数 组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 
$value 并 且 数 组 内 部 的 指针 向 前 移 一 步 《 因 此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 ) 。 第 二 
种 格式 做 同样 的 事 ， 只 除了 当前 单元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key。 其 执行 


的 逻辑 结构 如 图 2-25 所 示 。 


False( 假 》 


图 2-25 foreach 语句 逻辑 示意 图 
该 语句 的 使 用 方法 如 下 : 
<?php 
S$arr = array ("one", "two", "three"); 
foreach ($arr as $value) { 


echo "Value: $value<br />\n"; 


此 段 代 码 的 输出 为 : 


Value: one 
Value: two 
Value: three 


在 这 段 代 码 中 遍历 数组 使 用 的 是 foreach 语 句 的 第 一 种 格式 ， 也 可 以 使 用 第 二 种 格式 ， 
改写 上 面 的 代码 如 下 : 


<?PhP 

$arr = array("one"， "two", "three") 
foreach ($arr as $key => $value) { 

echo "Key: $key; Value: $value<br />\n"; 
> 


此 段 代 码 的 输出 为 : 


Key: 0; Value: one 
Key: 1; Value: two 
Key: 2; Value: three 


和 
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< 263 ) 其 他 语句 


为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程 序 的 设计 ，PHP 还 提供 了 一 些 其 他 
语句 ， 这 里 做 一 下 简单 的 介绍 。 


1. break 语句 
break 语 句 用 来 结束 当前 的 for、while 或 switch 循 环 结构 ， 继 续 执 行 下 面 的 语句 。break 
语句 后 面 可 以 跟 一 个 数字 ， 用 于 在 嵌 套 的 控制 结构 中 表示 跳出 控制 结构 的 层 数 。 


2. continue 语句 

continue 语 句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 面 的 语句 ， 而 是 回 到 循环 判断 表 
达 式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语 句 后 面 同样 可 以 跟 一 个 数字 ， 作 用 和 break 
语句 相同 。 


3. return 语句 
return0 语 句 通常 用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 return0 语 句 ， 将 立即 结束 此 函数 
的 执行 并 将 它 的 参数 作为 函数 的 值 返回 。 


4. include() 语 句 和 require() 语 句 

include() 语 句 和 require(0) 语 句 包 含 并 运行 指定 文件 。 require0 和 include(O 除 了 处 理 失败 之 
外 ， 在 其 他 方面 都 完全 一 样 。include0 产 生 一 个 警告 ， 而 require0 则 导致 一 个 致命 错误 。 也 
就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 应 该 使 用 require0， 而 include0 则 会 继续 执行 
脚本 ， 同 时 也 要 确认 设置 了 合适 的 include_path。 


5. require_once() 语 句 和 include_once() 语 名 

require_onceO0 语 句 和 include_once0 语 名 分别 对 应 require0 语 句 和 include0 语 句 。 
require_once() 语 句 和 include_onceO 语 句 主要 用 于 需要 包含 多 个 文件 时 ， 可 以 有 效 地 避免 把 
同一 段 代 码 包含 进去 而 出 现 函数 或 变量 重复 定义 的 错误 。 


2 2.7 PHP 函数 应 用 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 程序 写 在 一 起 ， 但 这 样 容易 引起 混乱 。 男 一 种 
策略 就 是 把 总 的 功能 分 成 小 的 功能 模块 ， 把 每 一 个 模块 分 别 实 现 ， 在 总 的 框架 中 根据 需要 
把 模块 搭建 在 一 起 。 实 现 程 序 模块 化 的 策略 就 是 使 用 函数 ， 直 观 来 说 ， 函 数 就 是 代表 一 组 
语句 的 标识 符 ， 在 使 用 函数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 
函数 的 输入 和 输出 接口 的 应 用 。 函 数 可 以 简单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 一 类 是 用 
户 自 定义 函数 。 对 于 系统 函数 ， 可 以 在 需要 时 直接 选择 使 用 ， 而 用 户 自 定义 函数 ， 首 先 要 
定义 ， 然 后 才能 使 用 。 本 节 的 重点 是 如 何 定义 并 使 用 用 户 自 定义 函数 ， 主 要 包括 函数 定义 
的 一 般 形 式 ， 函 数 的 参数 和 返回 值 ， 函 数 的 嵌 套 和 递归 等 。 


二 > 


多 2.7.1 ) 使 用 函数 


义 。 


一 个 函数 可 由 以 下 的 语法 来 定义 : 
function funcName([$arg 1][, $arg 2][，...][，S$arg_n])1{ 
statement 


} 


定义 函数 需要 使 用 function 关 键 字 , 之 后 是 函数 名 ， 有 效 的 函数 名 必须 以 字母 或 下 划 线 
打头 ， 后 面 跟 字母 ， 数 字 或 下 划 线 。$arg_1 到 $arg_n 为 函数 的 可 选 参 数列 表 ， 不 同 的 参数 
之 间 用 逗号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代码 ， 甚 至 包括 其 他 函数 和 类 定 


例如 : 


<?php 

function maxNum ($a, $b){ 
$c=$a>$b?$a: $b; 

return $c; 

} 

echo maxNum(10,100); // 输出 : 100 
人 


上 面 的 一 段 代 码 也 可 以 写成 : 

<?php 

echo maxNum(10,100); // 输出 : 100 
function maxNum ($a, $b){ 
$c=$a>$b?$a: $b; 

return $c; 

} 

es 


< 多 2.7.2 ) 设 置 函数 参数 
通过 函数 参数 列表 可 以 传递 信息 到 函数 ，PHP 支 持 按 值 传递 参数 。 默 认 情 况 下 ， 函 数 
参数 通过 值 传递 ， 即 若 在 函数 内 部 改变 了 参数 的 值 ， 也 不 会 影响 到 函数 外 部 的 值 。 


例如 : 


<?PhP 

function change ($string){ 
$string = "改变 之 后 "; 

} 

$str = "改变 之 前 "; 

change ($str); 

echo $str; 

Fs 


这 段 代码 的 输出 为 “改变 之 前 ”。 尽 管 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 没有 影 
响 到 函数 外 部 $str 的 值 。 如 果 希 望 允 许 函 数 修改 它 的 参数 值 ， 必 须 通 过 引用 传递 参数 ， 方 
法 是 在 函数 定义 中 该 参数 的 前 面 预先 加 上 & 符 号 。 


修改 上 面 的 代码 如 下 : 


re 
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<?php 


function change (&$string){ 
$string = "& 改 变 之 后 "; 

} 

$str = "改变 之 前 "; 

change ($str); 

echo $str; 

?> 


这 段 代 码 的 输出 为 “改变 之 后 ”。 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 影响 到 了 函 
数 外 部 $str 的 值 。 前 后 两 段 代 码 的 唯一 区 别 就 是 ， 后 面 一 段 代码 的 参数 传递 是 引用 传递 ， 
即 在 函数 定义 中 的 参数 前 面 加 上 了 有 & 符 号 。 


-273 返回 西数 值 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 。 主 要 通过 使 用 可 选 的 returnO 语 句 返 
回 值 。 任 何 类 型 都 可 以 返回 ， 其 中 包括 列表 和 对 象 。 这 导致 函数 立即 结束 它 的 运行 ， 并 且 
将 控制 权 传递 回 它 被 调用 的 行 。 

举例 如 下 : 

<?php 

$numl=100; 
$num2=200; 

echo " 较 大 的 是 " .maxNum ($numl， $num2); // 输出 : 较 大 的 是 200 

function maxNum ($a, $b){ 

if ($a<$b) $a = $b; 

return $a; 


} 
Fe 


僵 2.7.4 ) 函 数 嵌 套 和 递归 

PHP 中 的 函数 可 以 嵌 套 定义 和 藤 套 调用 。 所 谓 嵌 套 定义 ， 就 是 在 定义 一 个 函数 时 ， 其 
函数 体内 又 包含 另 一 个 函数 的 完整 定义 。 这 个 内 媒 的 函数 只 能 在 包含 它 的 函数 被 调用 之 后 
才 会 生效 ， 举 例如 下 : 

<?php 

function foo() 

{ 

function bar() 

{ 

echo "并 没有 关闭 直到 foo () 函数 被 应 用 ."; 

了 

} 

/* 不 能 谋 套 应 用 bar () 函数 ， 因 为 它 并 没有 被 关闭 . */ 

foo(); 

/* 现 在 可 以 应 用 bar () 函数 ， 

foo () 's 的 进程 允许 使 用 . */ 

bar(); 

2 


Bis 


RE 
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这 段 代码 的 输出 为 “并 没有 关闭 直到 foo0 函 数 被 应 用 。” 
所 谓 嵌 套 调用 ， 就 是 在 调用 一 个 函数 的 过 程 中 ， 又 调用 另 一 个 函数 。 举 例如 下 : 
<?php 
$numl=100; 
$num2=200; 
myoutput ($numl, $num2); 
function myoutput ($a, $b){ 
echo " 较 大 的 是 " .maxNum ($a, $b); 
} 
function maxNum ($a, $b){ 
if($a<$b) $a = $b; 
return $a; 
} 
?> 
这 段 代 码 的 输出 是 “ 较 大 的 是 200”。 在 此 段 代 码 中 首先 调用 的 myoutputO0， 而 在 调用 
这 个 函数 的 过 程 中 ， 又 调用 了 另 一 个 函数 maxNum()， 这 就 是 函数 的 储 套 调用 。 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 间接 地 调用 该 函 
数 本 身 。 举 例如 下 : 
<?php 
recursion (5) 7 
function recursion ($a) 
{ 
if ($a <= 10) 1{ 
echo "$a "™; 
recursion($a + 1); 
} 
} 
?> 
这 段 代 码 的 输出 是 数字 5，6，7，8，9，10。 在 此 段 代 码 中 首先 调用 的 recursion0)， 而 
在 调用 这 个 函数 的 过 程 中 ， 如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 身 ， 这 就 是 函数 
的 递归 调用 。 嵌 套 和 递归 在 使 用 PHP 进 行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 读者 举 
一 反 三 ， 清 晰 地 掌握 逻辑 关系 后 方 可 以 进行 应 用 ， 否 则 很 容易 出 现 死 循环 。 


有 F1 2.8 ”MySQL 数据 库 操作 


要 想 快 速成 为 PHP 网 页 编程 高 手 ， 核 心 掌握 MySQL 的 数据 库 操 作 是 非常 重要 的 ， 一 般 
PHP 实 现 对 MySQL 的 操作 主要 包括 连接 、 创 建 、 插 入 、 选 择 、 查 询 、 排 序 、 更 新 以 及 删除 
等 操作 ， 下 面 就 分 别 介绍 一 下 实现 这 些 功能 的 函数 命令 。 

人 2.8.1 ) 连 接 数据 库 (MYSQL_CONNECT()) 

在 能 够 访问 并 处 理 数据 库 中 的 数据 之 前 ， 必 须 创 建 到 达 数 据 库 的 连接 。 在 PHP 中 ， 这 
个 任务 通过 mysql_connect0 函 数 完成 。 

语法 : 


mysql_connect (servername,username, password); 


gs 


3) 
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举例 如 下 : 

在 下 面 的 例子 中 ,我 们 在 一 个 变量 中 ($conn) 存放 了 在 脚本 中 供 以 后 使 用 的 连接 。 如 
果 连 接 失败 ， 将 执行 die 部 分 。 

<?php 


$conn = mysql connect ("localhost","root","admin"); 
if (!$conn) 


{ 
die (' 不 能 连接 数据 库 : ' . mysql error()); 
} 


人 


脚本 一 结束 ， 就 会 关闭 连接 。 如 需 提 前 关闭 连接 ， 则 使 用 mysql_close( 函数 实现 


<?php 
$conn = mysql connect ("localhost","root","admin"); 
if (!$conn) 
{ 
die (' 不 能 连接 数据 库 : ' . mysql_error()); 
} 
mysql_close($conn); 
?> 


-282 ) 创 建 数据 库 (CREATE) 


CREATE DATABASE 语句 用 于 在 MySQL 中 创建 数据 库 。 
语法 : 
CREATE DATABASE database name 


为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 使 用 mysql_queryO 函数 。 此 函数 用 于 向 MySQL 连 
接 发 送 查 询 或 命令 。 

举例 如 下 : 

在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my_db 的 数据 库 。 


<?PhP 
$conn = mysql_connect ("localhost", "root","admin"); 
if (!$conn) 
{ 
die (' 不 能 连接 数据 库 : ' - mysql_error()); 
} 
if (mysql_ query ("CREATE DATABASE my_db",$conn)) 
{ 
echo "Database created"; 
} 
else 
1 
echo "Error creating database: " . mysql error(); 
} 
mysql_close($conn); 
有 > 
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CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
语法 : 


为 了 执行 此 命令 ， 必 须 向 mysql_query() 函数 添加 CREATE TABLE 语句 。 


举例 如 下 : 
下 面 的 例子 展示 了 如 何 创建 一 个 名 为 Persons 的 表 ， 此 表 有 三 列 。 列 名 是 FirstName， 
LastName 以 及 Age。 


在 创建 表 之 前 ， 必 须 首 先 选择 数据 库 。 通 过 mysql_select_db0 函数 选取 数据 库 。 当 创 
建 varchar 类 型 的 数据 库 字 段 时 , 必须 规定 该 字段 的 最 大 长 度 , 例如 : varchar(15)。MySQL 
各 种 数据 类 型 如 表 2-8~ 表 2-11 所 示 。 


,0 
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表 2-8 ”MySQL 数据 类 型 表 


int(size) 


smallint(size) 

tinyint(size) 仅 支 持 整 数 。 在 size 参数 中 规定 数字 的 最 大 值 
mediumint(size) 

bigint(size) 


decimal(size,d) 
double(size,d) 
float(size,d) 


支持 带 有 小 数 的 数字 。 在 size 参数 中 规定 数字 的 最 大 值 。 在 d 参数 中 规定 小 
数 点 右 侧 的 数字 的 最 大 值 


表 2-9 文本 数据 类 型 表 
文本 数据 类 型 描述 


支持 固定 长 度 的 字符 串 ( 可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参数 中 规 
定 固定 长 度 

支持 可 变 长 度 的 字符 串 。( 可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参数 中 
规定 最 大 长 度 


支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 


支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 


支持 可 变 长 度 的 字符 种， 最 大 长 度 是 16777215 个 字符 
mediumblob 

支持 可 变 长 度 的 字符 种， 最 大 长 度 是 4294967295 个 字符 
longblob 


表 2-10 日 期 数据 类 型 表 


日 期 数据 类 型 描述 
date(yyyy-mm-dd) 支持 日 期 或 时 间 
datetime(yyyy-mm-dd hh:mm:ss) 
timestamp(yyyymmddhhmmss) 

time(hh:mm:ss) 


表 2-11 ”杂项 数据 类 型 表 
杂项 数据 类 型 描述 


enum(valuel,value2,ect) ENUM 是 ENUMERATED 列表 的 缩写 。 可 以 在 括号 中 存放 最 
多 65535 个 值 


Set SET 与 ENUM 相似 。 但是, SET 可 拥有 最 多 64 个 列表 项 目 ， 
并 可 存放 不 止 一 个 choice 


每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯一 标识 。 每 个 主键 值 在 表 中 
必须 是 唯一 的 。 此 外 ， 主 键 字段 不 能 为 宝 ， 这 是 由 于 数据 库 引擎 需要 一 个 值 来 对 记录 进行 
定位 。 主 键 字 段 永远 要 被 编 入 索引 。 这 条 规则 没有 例外 。 必 须 对 主键 字段 进行 索引 ， 这 样 


= 当世 = 


en 多 
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数据 库 引 擎 才能 快速 定位 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字 段 设置 为 主键 字段 。 主 键 字段 通常 是 ID 号 ， 且 通常 使 用 
AUTO _INCREMENT 设置 .AUTO_INCREMENT 会 在 新 记录 被 添加 时 逐一 增加 该 字段 的 
值 。 要 确保 主键 字段 不 为 空 ， 必 须 向 该 字段 添加 NOT NULL 设置 。 


举例 如 下 : 
$sql = "CREATE TABLE Persons 


( 
PersonID int NOT NULL AUTO INCREMENT, 


PRIMARY KEY (personID), 
FirstName varchar(15), 
LastName varchar (15), 
Age int 

J 

mysql_ query($sql,$conn); 


优 2.8.3 ) 插 入 数据 (INSERT INTO) 


INSERT INTO 语 句 用 于 向 数据 库 表 添加 新 记录 。 
语法 : 

INSERT INTO table name 

VALUES (valuel, value2,....) 


还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 
INSERT INTO table name (columnl, column2,...) 
VALUES (valuel, value2,....) 


SQL 语句 对 大 小 写 不 敏感 。INSERT INTO 与 insert into 相同 。 为 了 让 PHP 执行 该 
语句 ， 必 须 使 用 mysql_query0 函 数 。 该 函数 用 于 向 MySQL 连 接 发 送 查 询 或 命令 。 


举例 如 下 : 
在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 其 中 有 三 个 列 : Firstname、Lastname 和 Age。 下 
面 将 在 本 例 中 使 用 同样 的 表 ， 向 Persons 表 添加 两 个 新 记录 。 
<?php 
$conn = mysql_connect ("localhost", "root","admin"); 
if (!$conn) 
{ 
die (' 不 能 连接 数据 库 : ' . mysql error()); 
} 
mysql_select db("my db", $conn); 
mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES Chen "yicai, 35 7 
mysql_query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES (yu', "heyun"y "28")")s 


= 


mysql_close($conn); 
?> 


择 数 据 (SELECT) 


SELECT 语句 用 于 从 数据 库 中 选择 数据 。 
语法 : 
SELECT column name(s) FROM table name 


SQL 语 句 对 大 小 写 不 敏感 ，SELECT 与 select 等 效 。 为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 


使 用 mysql_query() 函数 ， 该 函数 用 于 向 MySQL 发 送 查 询 或 命令 。 


下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 (* 字符 选取 表 中 所 有 数据 ) 。 
<?php 
$conn = mysql_connect ("localhost", "root","admin"); 
if (!$conn) 
{ 
die (' 不 能 连接 数据 库 : ' . mysql_error()); 
} 
mysql_select db("my db", $conn); 
$result = mysql query ("SELECT * FROM Persons"); 
while ($row = mysql_ fetch array ($result)) 
{ 
echo $row['FirstName'] . " " . $row['LastName']; 
echo "<br />"; 
} 
mysql_close($conn); 
多 


上 面 这 个 例子 在 $result 变 量 中 存放 由 mysql_query0 函数 返回 的 数据 。 接 下 来 ， 使 用 


mysql_fetch_arrayO 函 数 以 数组 的 形式 从 记录 集 返 回 第 一 行 。 每 个 随后 对 mysql_fetch_array() 


函数 的 调用 都 会 返回 记录 集中 的 下 一 行 。while loop 语 句 会 循环 记录 集中 的 所 有 记录 。 为 了 


输出 每 行 的 值 ， 使 用 了 PHP 的 Srow 变 量 ($row['FirstrName'] 和 S$row['LastName'])。 


和 255 ) 条 件 查 询 (WHERE) 


如 需 选 取 匹 配 指定 条 件 的 数据 ， 请 向 SELECT 语句 添加 WHERE 子 句 。 
语法 : 

SELECT column FROM table 

WHERE column operator value 


下 面 的 运算 符 如 表 2-12 所 示 ， 可 与 WHERE 子 句 一 起 使 用 。 
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表 2-12 ”可 用 于 查询 的 运算 符 


小 于 
>= 大 于 或 等 于 
<= 小 于 或 等 于 
BETWEEN 介 于 一 个 包含 范围 内 
LIKE 搜索 匹配 的 模式 
举例 如 下 : 
下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName='Root 的 行 。 
<?php 


$conn = mysql_connect ("localhost", "root","admin"); 
if (!$conn) 

{ 

die (' 不 能 连接 数据 库 : ' . mysql_error()); 

} 
mysql_select db("my db", $conn); 
$result = mysql_ query ("SELECT * FROM Persons 
WHERE FirstName='chen'"); 


while (Srow = mysql_ fetch array($result)) 


证 
echo $row['FirstName'] . " " . $row['LastName']; 


echo "<br />"; 
} 


-从 256 ) 数 据 排序 (ORDER BY) 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 
SELECT column_name (s) 


FROM table name 
ORDER BY column name 


举例 如 下 : 
下 面 的 例子 选取 persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 。 


<?PhP 
$conn = mysql_connect ("localhost","root","admin"); 


-85- 


Pe 网 站 开发 全 程 实例 (第 2 版 》 
MSS @Ce 


if (!$conn) 
die (' 不 能 连接 数据 库 : ' . mysql error()); 
} 
mysql_ select dbl("my db", $conn); 
$result = mysql query ("SELECT * FROM Persons ORDER BY age"); 
while($row = mysql fetch array($result)) 
{ 
echo $row['FirstName']; 
echo " " . $row['LastName']; 
eCho ™ ™ . $rowl'MAge']s 
cho Mbr />™y 
} 
mysql_ close($conn); 


如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 (1 在 9 之 前 ，a 在 p 之 前 ) 。 
使 用 DESC 关键 词 来 设 定 降序 排序 (9 在 1 之 前 ，p 在 a 之 前 〉。 
SELECT column name (s) 


FROM table name 
ORDER BY column name DESC 


可 以 根据 两 列 进行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 
有 第 一 列 相 同时 才 使 用 第 二 列 。 
SELECT column_name (s) 


FROM table name 
ORDER BY column namel, column name2 


入 287 ) 更 新 数据 (UPDATE) 


UPDATE 语 句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table name 


SET column name = new_ value 
WHERE column name = some value 


举例 如 下 : 
通过 下 面 的 例子 更 新 Persons 表 的 一 些 数据 。 


<?php 
$conn = mysql connect ("localhost","root","admin"); 
if (!$conn) 
{ 
die (' 不 能 连接 数据 库 : ' . mysql _ error()); 
} 
mysql_select db("my db", $conn); 
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DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 
语法 : 


举例 如 下 : 


本 小 节 介 绍 了 PHP 实 现 对 MySQL 数 据 库 的 一 些 常 用 操作 ,读者 在 学 习 的 时 候 一 定 要 认 
真 编写 每 一 行 的 代码 ， 养 成 规范 ， 方 便 后 面 内 容 的 学 习 。 


,a 


第 章 


全 程 实例 一 : 成 绩 得 询 系统 


进行 PHP 网 站 开发 的 环境 有 很 多 ， 对 于 已 经 很 熟悉 HTML 语 言 和 PHP 的 设计 人 员 甚 至 
可 以 直接 使 用 记事 本 进行 代码 的 编写 工作 ; 对 于 新 手 来 说 可 以 使 用 Dreamweaver 配 合 
MySQL 进 行动 态 系统 的 开发 。Dreamweaver 提 供 了 方便 的 图 形 化 界面 ， 只 需 使 用 鼠标 选 
择 ， 输 入 一 些 基 本 设置 参数 就 能 够 与 MySQL 数 据 库 交互 ， 实 现 建立 数据 ， 查 询 ， 新 增 记 
录 ,更 新 记录 ,删除 记录 等 操作 ， 不 用 自己 写 程序 即 可 以 实现 PHP+MySQL 动 态 系统 的 开 
发 。 本 章 将 介绍 如 何 使 用 Dreamweaver 的 服务 器 行为 ， 引 导读 者 熟悉 由 Dreamweaver 
所 产生 的 程序 代码 、 掌 握 Dreamweaver 绑 定 生成 的 PHP 程 序 逻 辑 。 


本 章 的 学 习 重 点 : 

掌握 Dreamweaver 进 行 PHP 开 发 的 流程 
在 Dreamweaver 进 行 PHP 开 发 平台 的 搭建 
搭建 PHP 动 态 系统 开发 的 平台 

检查 数据 库 记 录 的 常见 操作 
编辑 记录 的 常见 操作 


1 3.1 ”搭建 PHP 开 发 环境 


Dreamweaver 提 供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 支持 不 同 服务 器 技术 ， 如 ASP、 
PHP、JSP 等 等 ， 建 立 动态 支持 数据 库 的 网 络 应 用 程序 。 同 时 也 能 让 不 懂 程 序 代码 的 网 站 设 
计 人 员 或 初学 者 能 在 不 用 撰写 程序 代码 的 情况 下 ， 学 习 动 态 网 页 技术 的 设计 。 


<- 3171 ) 网 站 开发 的 步 又 


在 开始 制作 网 站 之 前 ,还 要 了 解 在 Dreamweaver CC 中 的 网 页 设计 和 发 布 流程 。 它 可 以 
分 为 如 下 5 个 主要 步骤 : 


第 一 步 : 规划 网 站 站 点 
需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 ， 针 对 的 是 什么 样 的 访问 者 ， 以 确定 
网 页 中 应 该 出 现 什么 内 容 。 


第 二 步 : 建立 站 点 的 基本 结构 

在 Dreamweaver CC 中 可 以 在 本 地 计算 机 上 建立 出 整个 站 点 的 框架 , 并 在 各 个 文件 夹 中 
合理 地 安置 文档 。Dreamweaver CC 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 种 是 目 
录 结 构 ， 另 一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 
了 本 地 站 点 并 生成 了 相应 的 站 点 结构 ， 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 就 可 以 在 其 中 
组 织 文 档 和 数据 。 


第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CC 软件 中 ， 开 始 进行 页 面 的 版 面 规划 设计 ， 利 用 强 
大 的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 再 组 织 页 面 内 容 。 为 了 保持 页 面 的 统一 风格 
可 以 利用 模板 来 快速 生成 文档 。 


第 四 步 : 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 就 要 往 框架 里 填充 内 容 。 在 文档 窗口 中 合适 的 地 方 ， 可 以 
输入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插 件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面 
板 或 插入 菜单 来 完成 插入 。 


第 五 步 : 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服 务 器 上 的 远 端 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 随时 更 新 和 维护 。 
< 3.1.2 ) 网 站 文件 夹 设计 

在 制作 网 站 之 前 首先 是 把 设计 好 的 网 站 内 容 放 置 在 本 地 设计 计算 机 的 硬盘 上 ， 为 了 方 
便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服 务 器 的 安装 路 径 下 ， 如 本 书 的 路 


ss 
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径 为 C:\XAMPP\htdocs 目 录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 ， 在 本 地 站 点 规划 的 时 候 ， 
应 该 注意 如 下 的 操作 规则 : 


1.， 设计 合理 的 文件 夹 

在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 
夹 ， 然 后 再 在 其 中 创建 多 个 子 文件 夹 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 例 如 可 以 
在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 data 文 件 夹 中 放置 网 站 的 数据 库 ， 可 以 
在 css 文 件 夹 中 放置 网 页 的 样式 表 , 如 图 3-1 所 示 的 一 个 phpweb 网 站 规划 建立 的 文件 夹 文档 。 


| 
Os， + , ser Cy » XAMFP » hdocs ，phpoeb ， Er | 
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图 3-1 网 站 在 本 地 硬盘 上 的 文件 夹 建立 


2. 设计 合理 的 文件 名 称 
网 站 建设 由 于 要 生成 的 文件 很 多 ， 所 以 经 常 要 用 合理 的 文件 名 称 。 这 样 操作 的 目的 一 
是 为 了 方便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 新 ; 其 二 也 是 为 了 方便 浏览 者 在 看 
了 网 页 的 文件 名 就 能 够 知道 网 页 所 要 表述 的 内 容 。 
在 设计 合理 的 文件 名 时 要 注意 以 下 几 点 : 
@ 第 一 : 尽量 使 用 短文 件 来 命名 。 
@ 第 二 : 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Internet 服 务 器 使 用 的 是 英文 操作 系统 ， 
不 能 对 中 文 文件 名 提供 很 好 的 支持 ， 而 且 浏 览 网 站 的 用 户 也 可 能 使 用 英文 操作 系 
统 ， 中 文 文件 名 同样 可 能 导致 浏览 错误 或 访问 失败 。 
@ 第 三 : 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服 务 器 采用 
Unix 操 作 系统 ， 它 是 区 分 文件 的 大 小 写 的 。 


3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 

在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同上 传 到 Internet 服 务 器 中 被 人 浏览 的 网 站 
文件 结构 相同 。 这 样 在 本 地 站 点 上 相应 的 文件 夹 和 文件 上 的 操作 ， 都 可 以 同 远程 站 点 上 的 
文件 夹 和 文件 一 一 对 应 。 Dreamweaver CC 将 整个 站 点 上 传 到 Internet 服 务 器 上 , 都 可 以 保证 
远程 站 点 是 本 地 站 点 的 完整 的 复制 ， 方 便 浏 览 和 修改 。 
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BS 3.1.3 ) 流 畅 的 浏览 顺序 


在 网 站 创建 的 时 候 首先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 
是 否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻 松 自如 地 访问 每 个 他 们 要 访 
问 的 网 页 。 这 样 能 提高 用 户 浏览 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 
如 下 几 个 方面 的 浏览 顺序 : 

@ 在 每 个 页 面 建立 主页 的 链接 

在 网 站 所 有 的 页 面 上 , 都 要 放置 返回 主页 的 链接 。 如 果 在 网 页 中 包含 返回 主页 的 链接 ， 
就 可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ， 快 速 返回 到 主页 中 ， 重 新 开始 浏览 站 点 
中 其 他 内 容 。 

@ 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 过 导航 提供 站 点 的 简明 目录 结构 ， 引 导 
用 户 从 一 个 页 面 快速 进入 到 其 他 的 页 面 上 。 

@ 突出 当前 页 位 置 

在 网 站 页 面 的 设计 中 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 的 
主题 ， 以 帮助 浏览 者 了 解 他 们 现在 访问 的 是 什么 地 方 。 如 果 页 面 嵌 套 过 多 ， 则 可 以 通过 创 
建 “ 前 进 ” 和 “后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

@ 增加 搜索 和 索引 功能 

对 于 一 些 带 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 是 给 浏览 者 提供 索引 
检索 的 权利 ， 使 用 户 能 快速 查找 到 自己 需要 的 信息 。 

@ 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 他 们 对 网 点 的 意见 和 
建议 是 非常 重要 的 ， 为 了 及 时 从 用 户 处 了 解 到 相关 信息 ， 应 该 在 网 页 上 提供 用 户 同 网 页 创 
作者 或 网 站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 每 或 是 创建 一 个 E-mail 超 级 链接 ， 
帮助 用 户 快 速 将 信息 回馈 到 网 站 中 。 


> 3.2 成 绩 查 询 系统 环境 


本 小 节 就 以 实例 “成 绩 查 询 ” 系 统 的 形式 具体 介绍 Dreamweaver 中 的 服务 器 行为 的 使 
用 方法 。 在 开始 制作 一 个 PHP 网 站 之 前 ， 需 要 在 Dreamweaver 中 定义 一 个 新 站 点 。 在 “新 
建站 点 ”中 可 以 让 Dreamweaver 知 道 ， 现 在 网 站 的 本 地 目录 ， 测 试 的 路 径 等 信息 。 


< 51) 查询 系统 设计 


“成 绩 查询 ”系统 结构 主要 分 成 用 户 登 录入 口 与 找 回 密码 入 口 两 个 部 分 ， 其 中 
index.php 是 这 个 网 站 的 首页 。 
在 本 地 的 计算 机 设置 站 点 服务 器 ， 除 在 Dreamweaver CC 的 网 站 环境 下 按 F12 键 来 浏览 
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网 页 之 外 ， 还 可 以 在 IE 浏 览 器 输入 “http://localhost/phpweb/index.php” 来 打开 用 户 系 统 的 
首页 index.php， 其 中 phpweb 为 站 点 名 。 
本 实例 制作 5 个 功能 页 面 ， 各 页 面 的 功能 如 表 3-1 所 示 。 


表 3-1 网 页 功能 表 
页 面 主要 的 功能 


用 来 显示 所 有 的 成 绩 记录 
显示 详细 成 绩 信息 页 面 


更 新 成 绩 信息 页 面 
删除 成 绩 信息 页 面 

index.php 用 于 浏览 数据 库 内 记录 ， 为 detail.php 提 供 附带 URL 参 数 ID 的 超级 链接 ， 便 于 
查看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 


增加 成 绩 信息 页 面 
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图 3-2 index 页 面 效果 


detail.php 用 于 接收 由 index.php 传 来 的 URL 参 数 ID ， 利 用 URL 参 数 筛 选 数据 库 中 的 记 
录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 
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图 3-3 detal.php 页 面 效果 
当 制 作 一 个 PHP 系 统 功 能 时 ， 提 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 在 我 们 的 脑 
子 里 这 个 网 站 要 有 一 个 雏形 ， 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 的 架构 规划 
也 是 一 样 的 ， 要 有 哪些 数据 表 、 字 段 ， 如 何 跟 网 页 配合 等 都 是 很 重要 的 工作 。 


-G522 创建 数据 库 


经 过 对 前 面 功能 的 分 析 发 现 ， 数 据 库 应 该 包括 ID， 姓 名 ,年龄 ， 成 绩 4 个 字段 。 所 以 
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在 数据 库 中 必须 包含 一 个 容纳 上 述 信息 的 表 ， 将 数据 库 命 名 为 pppweb， 接 下 来 就 要 使 用 
phpmyAdmin 软 件 建立 网 站 数据 库 websql 作 为 任何 数据 查询 、 新 增 、 修 改 与 删除 的 后 端 支 
持 。 

创建 的 步骤 如 下 : 


在 下 浏览 器 中 输入 http://127.0.0.1/phpmyadmin/， 输 入 MySQL 的 用 户 名 和 密码 
Po 和 

加 单 去“ 执行 ”按钮 即 可 以 进入 软件 的 管理 界面 ， 选 择 相关 数据 库 可 看 到 数据 库 中 
Rn 可 进行 表 、 Ed ol 可 以 导入 、 导 出 数据 库 信 息 ， 如 图 3-4 所 示 。 
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图 34 软件 的 管理 界面 
单 击 下 WE 命令 ， 打 开本 地 的 “数据 库 ” 管 理 页 面 ， 在 “新 建 数 据 库 ”文本 框 中 输 


入 数据 库 的 名 称 phpweb， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 框 ， 在 弹出 的 下 拉 菜 单 中 选择 
utf8_general_ci 选 项 ， 如 图 3-5 所 示 。 
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图 3-5 软件 的 管理 界面 
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; UTF8 是 数据 库 的 编码 格式 , 通常 在 开发 PHP 动 态 网 站 的 时 候 Dreamweaver 默 认 的 格式 就 是 UTF8 
; 格式 ， 在 创建 数据 库 的 时 候 也 要 保证 数据 库 储存 的 格式 和 网 页 调用 的 格式 一 样 ， 这 里 要 介绍 一 
: 下 utf8_bin 和 utf8_general_ci 的 区 别 。 其 中 ci 是 case insensitive， 即 “大 小 写 不 敏感 ”，a 和 A 在 
; 字符 判断 中 会 被 当做 一 样 的 ，bin 是 二 进 制 ，a 和 A 会 被 区 别 对 待 。 

单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ” 页 面 ,在 数据 库 列 表 中 就 已 经 建立 了 phpweb 
的 数据 库 ， 如 图 3-6 所 示 。 
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图 3-6 创建 后 的 页 面 


数据 库 建立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 是 
websql。 建 立 数据 库 后 ， 接 着 单 击 左边 的 phpweb 数 据 库 将 其 连接 上 ， 如 图 3-7 所 示 。 
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图 3-7 开始 建 数据 表 


打开 数据 库 右 方 画面 会 出 现 “新 建 数 据 表 ”的 设置 区 域 ， 含 有 “名 字 ”、“ 字 段 
数 ”两 个 文本 框 ， 在 “名 字 ” 中 输入 数据 表 名 websql，“ 字 段 数 ”文本 框 中 输入 本 数据 表 
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的 字段 数 为 4， 表 示 将 创建 4 个 字段 来 储存 数据 ， 如 图 3-8 所 示 。 
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图 3-8 输入 数据 表 名 websql 和 字段 数 


再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设 
置 数据 域 位 的 相关 数据 ， 如 图 3-9 所 示 。 各 字段 的 意义 如 表 3-2 所 示 。 这 个 数据 表 主要 是 记 
录 每 个 人 的 基本 数据 和 成 绩 。 


表 3-2 ”websql 数 据 表 


字段 名 称 
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图 3-9 设置 数据 库 字 段 属性 
国 最 后 再 单 击 “ 保 存 ” 按 钮 ， 切 换 到 “结构 ”页 面 。 实 例 将 要 使 用 的 数据 库 建立 完 
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， 如 图 3-10 所 示 。 
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图 3-10 建立 的 数据 库 页 面 


国 为 了 页 面 制作 的 调用 需要 ， 可 以 先 在 数据 表 里 加 入 10 笔 数据 ， 在 数据 表 手 动 加 入 

名 为 testl~test10 的 10 个 测试 姓名 ， 年 龄 成绩 也 编辑 不 同 的 数据 ， 如 图 3-11 所 示 。 
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图 3-11 加 入 10 笔 数据 


-523 ) 定 义 Web 站 点 


在 Dreamweaver CC 中 创建 一 个 “成 绩 查 询 ” 网 站 站 点 phpweb， 由 于 这 是 PHP 数 据 库 网 
站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 3-3 所 示 。 
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表 3-3 ”站 点 设置 的 基本 参数 


站 点 名 称 web 


二 机 要 目录 
条 
网 站 测试 地 二 


MySQL 服 务 器 地 址 
root / 空 
phpweb 
创建 web 站 点 的 具体 操作 步骤 如 下 : 
加 在 C:XAMPP\htdocs 路 径 下 建立 phpweb 文 件 夹 (如 图 3-12 所 示 ) ， 本 实例 所 有 建 
立 的 网 页 文件 都 将 放 在 该 文件 夹 底下 。 
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图 3-12 建立 站 点 文件 夹 phpweb 
贺 启动 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 
理 站 点 ”对 话 框 ， 如 图 3-13 所 示 。 
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图 3-13 “管理 站 点 ”对 话 框 
国 单 击 “ 新 建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 ” 对 话 框 ， 左 边 是 站 点 列表 框 ， 其 
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中 显示 了 可 以 设置 选项 。 进 行 如 图 3-14 所 示 的 参数 设置 ， 设 置 站 点 名 称 为 phbpweb， 本 地 站 
点 文件 夹 地 址 为 C:\XAMPP\htdocs\phpweb。 


站 点 设 轩 对 银 phpweb 本 柯 荐 本 
如 es 计 是 网 站 中 估 肯 的 所 让 区 休 和 交合 ，p 
二 ee 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 去 和 名 称 * 
站 点 名 称 : [phpweb | 
本 地 让 点 文件 夹 : [C WAMPP htdocs\phpweb\ 辆 
ED 驻 


图 3-14 建立 web 站 点 


加 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ]， 打 开 “ 基 本 ” 
选项 卡 进 行 如 图 3-15 所 示 的 参数 设置 。 


图 3.15 基本” 选项 卡 设置 
设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选 项 (表示 是 使 用 PHP 
开发 的 网 页 ) ， 其 他 的 保持 默认 值 ， 如 图 3-16 所 示 。 
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图 3-16 设置 “高 级 ”选项 卡 


国 单 击 “ 保 存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 图 3-17 
所 示 。 
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图 3-17 设置 “服务 器 ”参数 

单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 
刚才 所 设置 的 站 点 web。 单 击 “ 完 成 ”按钮 ， 关 闭 “管理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CC 测 试 web 站 点 的 网 站 环境 设置 。 


< 324 建立 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 需 要 将 网 站 与 前 面 建立 的 price 数 据 库 建立 连接 。 

网 站 与 数据 库 的 连接 步骤 如 下 : 

加 执行 菜单 栏 “ 文 件 ” 一 “新 建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 index.php 的 
网 页 ， 输 入 网 页 标题 “PHP 动态 系统 ”， 然 后 执行 菜单 栏 “ 文 件 ” -~ “保存 ”命令 将 网 页 
保存 ， 如 图 3-18 所 示 。 

贺 执行 菜单 栏 上 的 “窗口 ” 一 “数据 库 ” 命 令 ， 打 开 “数据 库 ” 面板 。 在 “数据 
库 ” 面 板 中 单 击 “+” 图 标 ， 并 在 打开 的 菜单 中 选择 ”MySQL 连接 ”选项 ， 如 图 3-19 所 示 。 


-090 


洒 
(es he i (第 2 版 ) 


DW mmm sm se SMD me 一生 Ea 


加 
1 


设置 站 点 的 测试 服务 器 
单 击 上 面 的 + 按钮 创建 连接 。 


图 3-18 创建 空白 网 页 图 3-19 选择 MySQL 连接 
在 “MySQL 连 接 ” 对 话 框 中 ， 输 入 “连接 名 称 ” 为 webconn， “MySQL 服 务 器 ” 
名 为 localhost，“ 用 户 名 ”为 root， 密 码 为 空 。 选 择 所 要 建立 连接 的 数据 库 名称 ， 可 以 单 击 
“选取 ”按钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 。 选 择 刚 导入 的 范例 数据 库 phpweb， 具 
体 的 设置 内 容 如 图 3-20 所 示 。 
园 单 击 “ 测 试 ”按钮 测试 与 MySQL 数 据 库 的 连接 是 否 正确 ， 如 果 正确 则 弹出 一 个 提 
示 消 息 框 (如 图 3-21 所 示 ) ， 这 表示 数据 库 连 接 已 设置 成 功 。 


My5QL 连 六 


连接 名 称 vboem 
MySQL 服务 器 :localhest 


图 3-20 设置 MySQL 连接 参数 图 3-21 设置 成 功 


单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 3-22 所 示 。 

在 建立 完成 MySQL 连 接 后 ， 在 “文件 在 ”面板 中 会 看 到 Dreamwaver 自 动 建立 了 
Connections 文 件 夹 , 在 该 文件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连 接 名 称 相同 的 文件 ,如 
图 3-23 所 示 。 
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图 3-22 绑 定 的 数据 库 图 3-23 ”自动 生成 的 webconn.php 文件 
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Connections 文 件 夹 是 Dreamweaver 用 来 存放 MySQL 连 接 设置 文件 的 文件 夹 。 打 开 该 文 
件 并 使 用 “代码 ”视图 ， 可 以 看 到 有 关连 接 数据 库 的 设置 ， 如 图 3-24 所 示 。 
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图 3-24 ”数据 库 连 接 设置 
在 这 个 文件 中 定义 了 与 MySQL 服 务 器 的 连接 (mysql_pconnect 函 数 )， 包 插 以 下 内 容 。 


@ $hostname: MySQL 服 务 器 的 地 址 。 

@ S$database: 连接 数据 库 的 名 称 。 

@ Susername: 用 户 名 称 。 

@ Spassword: 用 户 密 码 。 

定义 的 值 与 我 们 前 面 在 图 形 界面 所 设置 的 值 是 对 应 的 ,然后 利用 函数 mysql_pconnect 与 数 
据 库 连接 。 连 接 后 才能 对 数据 库 进 行 查询 、 新 增 、 修 改 或 删除 的 操作 。 如 果 在 网 站 制作 完成 
后 将 文件 上 传 至 网 络 上 的 主机 空间 时 发 现 ， 网 络 上 的 MySQL 服 务 器 访问 的 用 户 名 、 密 码 等 方 
面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connection 文 件 夹 下 的 webconn.php 文 件 。 


1 3.3 ”动态 服务 器 行为 


在 Dreamweaver 中 可 以 利用 软件 自 带 的 动态 服务 器 行为 快速 建立 一 些 基本 动态 功能 ， 
本 小 节 就 介绍 在 Dreamweaver 中 与 检查 数据 库 记 录 相 关 的 “服务 器 行为 ”， 主 要 包括 了 创 
建 记 录 集 、 插 入 记录 、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 集 分 页 等 常用 的 动态 服务 器 
行为 。 


LT 创建 新 记录 集 


在 每 个 需要 查看 数据 库 记 录 的 页 面 中 丝 须 为 其 建立 一 个 “记录 集 (查询) ”， 从 而 可 
以 让 Dreamweaver 知 道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 
容 一 样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建立 一 次 MySQL 连 接 ， 但 我 们 可 
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为 同一 个 MySQL 数 据 库 连 接 建 立 多 个 “记录 集 ”， 配合 筛选 的 功能 达到 某 个 记录 集 只 包含 
数据 库 中 符合 某 些 条 件 的 记录 。 

打开 index.php 文 件 后 ， 然 后 打开 菜单 栏 上 的 “应 用 程序 ”一 “ 绑 定 ”面板 ， 选 择 “ 记 
录 集 (查询 ) ” 便 可 以 建立 记录 集 。“ 绑 定 ” 面 板 中 的 “记录 集 (查询 ) ”与 “服务 器 行 
为 ”面板 中 “记录 集 ” 是 相同 的 ， 如 图 3-25 所 示 。 


图 3-25 选择 “记录 集 ” 命 令 


按说 明 设置 各 项 字段 〈 如 图 3-26 所 示 ) ， 然 后 单 击 “ 测 试 ”按钮 ，Dreamweaver 会 显 
示 目 前 设置 所 返回 的 记录 集 内 所 有 记录 ， 如 图 3-27 所 示 ， 字 段 的 功能 说 明 如 表 3-4 所 示 。 


表 3-4 ”字段 与 功能 说 明 


字 段 说 了 明 
一 般 用 Recordset〔 记 录 集 ) 的 缩写 rs 作为 开头 


选择 所 建立 记录 集 的 数据 库 是 在 哪个 MySQL 连 接 
此 处 显现 该 数据 库 连接 中 所 有 的 数据 表 ， 以 及 所 选 数据 表 内 所 有 字段 
是 否 依据 条 件 利 选 记录 
是 否 依照 某 个 字段 值 进行 排序 。 比 如 ， 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 前 面 
位 置 ， 就 可 以 使 用 排序 的 功能 
记录 集 [ex 
本 
连接 : Eee EX L R 消 
中 ”表格 : |websal SS [ee 
| Em | 
| 下 加 全 部 日 过 证 的 


==- 


图 3-26 设置 记录 集 
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ee 


tsQLS 


ee 


和 

名 
EE EDELEE 
la 


Tol | [rat [| 
图 3-27 单 击 “测试 ”按钮 浏览 记录 集 

记录 集 使 用 到 的 就 是 SELECT 语句 ， 因 为 查询 出 来 的 结果 可 能 会 有 很 多 条 ， 所 以 称 为 
记录 集 ( 合 ) ， 而 “筛选 ”部 分 则 对 应 WHERE 子 句 。 

单 击 “ 测 试 ”按钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 做 任何 筛选 的 处 理 ， 所 以 会 返 
回 完整 的 所 有 记录 。 

可 以 单 击 “ 高 级 ”按钮 查看 该 SQL 语句 。 可 以 看 到 ，Dreamweaver 提 供 了 一 个 基本 的 
图 形 界面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 “高 级 ”窗口 中 可 以 看 到 相应 的 SQL 语句， 
另外 还 提供 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 界面 设置 无 法 满足 的 
情况 ， 如 图 3-28 所 示 。 

在 记录 集 建 立 完毕 后 ， 我 们 可 以 在 “应 用 程序 ”一 “ 绑 定 ” 面 板 中 查看 到 目前 页 面 里 
的 所 有 记录 集 , 以 及 各 记录 集中 的 字段 , 双击 记录 集 可 以 重新 打开 图 3-29 所 示 的 设置 窗口 。 


图 3-28 “高 级 ”记录 集 窗口 图 3-29 绑 定 的 记录 集 效果 
建立 记录 集 与 直接 写 SELECT 语 句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-30 
所 示 。 其 中 第 1 行 的 require_once 函 数 是 用 来 引入 文件 的 ， 即 前 面 介绍 过 的 webconn.php。 在 
Dreamweaver 中 ， 若 是 我 们 已 经 定义 好 数据 库 连 接 ， 那 么 在 其 他 建立 记录 集 、 更 新 记录 、 
插入 记录 、 删 除 记 录 的 页 面 中 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 《这 就 是 为 什 
么 在 同一 个 站 点 中 只 需要 定义 一 次 MySQL 数 据 库 连接 )， 因 为 该 文件 中 所 包括 的 与 数据 库 
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连接 相关 的 设置 需要 被 使 用 。 


Dw 文 HR” 纺 (E) 可 看 (VW) 振 和 D 个 M(M]) 相 &(O)】 主人 CG 站 SS) 春 DW) 才 sh(H) 


人 
贺 : 
slpe 
| <6 
加 > 
属性 
Sl Pe, so tei = 
| 证 人 PE Re Of 
SthaValae = get nagie_ surtes ec() ? stripslashes(Sthayalue) : Stheyulae， 
图 3-30 自动 生成 的 代码 
其 程序 具体 分 析 如 下 : 


(1) 第 34 行 引用 了 webconn.php 内 的 设置 (变量 $datebase_webconn 与 Swebconn 被 定义 
在 这 个 文件 中 ) 来 选择 数据 库 〈mysql_select_db0) ， 随 后 的 mysql_query( ) 所 作用 的 都 是 

(2) 第 35 行 定义 了 查询 数据 库 的 SQL 语句 。 

(3) 第 36 行 使 用 35 行 所 定义 的 SQL 语句 对 数据 库 执行 查询 操作 (mysql_query0) ， 此 
时 返回 结果 是 资源 标识 符 ， 还 不 能 被 使 用 。 

(4) 第 37 行 将 前 面 查询 的 结果 以 关系 型 数组 的 形式 (mysql_fetch_assoc0) 传 至 变量 
S$row_rsdb， 然 后 就 可 以 使 用 $row_ 记 录 集 名 称 [字段 名 称 ] 来 取得 记录 集 字段 值 。 

(5) 第 38 列 取得 查询 结果 的 记录 条 数 (mysql_num_rows0) 并 赋 给 变量 $totalRows_ 
rsdb 。 

(6) 最 后 mysql_free_result0 释 放 查 询 结果 与 占用 的 内 存 资源 。 


上 面 是 Dreamweaver 连 接 数 据 库 并 执行 查询 的 标准 步骤 ， 在 mysql_query($query_rsdb， 
$webconn) or die(mysql_errorO) 的 部 分 ， 若 or 前 面 语 句 出 现 错误 或 失败 ， 就 执行 or 后 面 的 程 
序 。 所 以 若 数据 库 查 询 失败 的 时 候 就 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 

在 一 般 PHP 程 序 中 ， 典 型 的 连接 与 查询 程序 类 似 下 面 的 例子 。 

mysql_select db ($database webconn, S$webconn); 

$query_rsdb = "SELECT * FROM websql"; 

Srsdb = mysql query ($query rsdb, $webconn) or diel(mysql error()); 

$row rsdb = mysql fetch assoc($rsdb); 

$totalRows_rsdb = mysql _ num rows($rsdb); 

mysql free result($rsdb); 
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. © 
可 能 会 觉得 Dreamweaver 产 生出 来 的 程序 代码 比较 复杂 , 这 是 因为 Dreamweaver 建 立 的 
记录 集 需 要 搭配 很 多 服务 器 行为 来 使 用 。 


要 将 记录 集 内 的 记录 《〈 即 数据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步骤 如 下 : 


在 “文件 ”面板 中 打开 index.php， 在 网 页 中 制作 一 个 如 图 3-31 所 示 的 2x4 表 格 ， 然 后 
在 “应 用 程序 ”一 “ 绑 定 ”面板 上 选择 所 需 的 字段 并 拖 动 到 表格 中 。 


Dw rp wi wa AD RAM Wo) S50 ms) BOW sa 


Be- CB Ol-lol*] 


EN 


3 
ES 
[3 


式 WD [无 中 匡 无 EECIEEEET IO | 
ER 名 -OB Mo D 


A Rae Ca | 
本 于 可 WE 高 4 于 g 记 


i 
Ca E 


图 3-31 比 定 字段 
在 使 用 鼠标 拖 动 字段 至 页 面 上 放 开 后 ， 会 出 现 {rsdb.name} 的 字样 ， 其 中 rsdb 为 记录 集 


名 称 ，name 为 字段 名 称 。 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 拖 至 相应 的 单元 格 后 ， 
单 击 [实时 视 图 | 控 钮 。 


视图 所 呈现 的 效果 与 使 用 浏览 器 打开 网 页 一 样 ， 原 本 仅 显 示 { 记 录 集 名 称 .字段 名 称 } 
的 部 分 将 会 显示 出 记录 集 内 的 记录 ， 如 图 3-32 所 示 。 


Dw sun wan ss HAD aw Eo) ze0 el CIW sai - Bololx] 
ndexetp 和 
EI om po TE 
| | i [| ED ry -| 
1 se a OO | 
了 PHP 动态 系统 | 
二 一 Comectioe 邓 
用 本 E EE Er 邓 
1 etl 1 100 ea 9 


LP" 
ET 在 ~ Am] 
EE -人 -加 白 ” 名 冶 - 
[| i wR Nv OF He@ 1 ， 
| 3 2 王 标本 四 口 


图 3-32 实时 视图 效果 
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"5 op. 


再 单 击 一 次 [实时 视图 | 按钮 , 将 页 面 切换 到 [代码 视图 。 我 们 来 看 {记录 集 名 称 .字段 名 称 } 
的 部 分 代码 。 可 以 看 到 ， 程 序 代码 中 使 用 echo 来 输出 字段 值 ， 如 图 3-33 所 示 。 


DNS WAN ms- Ea oO-lol x] 


-BI 注 反 至 王 村 是 
-70 


EF] Wi POR RD | BBO 
| 总 中 Er 


图 3-33 ”代码 视图 效果 


<- 333 ) 重 复 区 域 功能 


在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 怎么 显示 出 来 呢 ? Dreamweaver 
提供 了 “重复 区 域 ” 及 “记录 集 分 页 ”的 功能 ， 只 需要 鼠标 拖 动 就 可 以 实现 这 个 功能 。 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ( 如 图 3-34 所 示 ) ， 然 后 在 “服务 器 行为 ” 面 
板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “重复 区 域 ” 如 图 3-35 所 示 。 


图 3-35 选择 重复 区 域 命令 
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二 


之 所 以 要 确认 选取 的 标签 为 <tr> ， 是 因为 重复 区 域 会 使 用 do.…while 循 环 包围 所 作用 
的 范围 。 而 需要 重复 的 仅 是 第 2 行 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 <tr > 标签 。 确 认 选 
取 的 标签 正确 ， 执 行 时 才 不 会 发 生 错误 。 
此 时 会 弹出 一 个 窗口 〈 如 图 3-36 所 示 ) ， 要 求 我 们 选择 要 重复 记录 的 记录 集 ， 以 及 需 
要 重复 几 条 记录 或 显示 全 部 记录 。 同 样 地 选择 [ 实时 视图 |， 这 时 就 可 以 看 到 原来 只 有 两 行 
的 表格 已 经 增长 到 6 行 〈 如 图 3-37 所 示 ) ， 而 记录 集 内 的 前 5 条 记录 都 显示 在 页 面 上 了 。 
重复 区 域 de 


图 3-36 设置 重复 区 域 


Dw rr al) EB BA aM xO) We(O) AlS) SOW RH Bm- 6 ol-lol*] 


yom 彬 式 思 无 HD 
Bes mw 二 "Gm “9 四 


SEE 


图 3-37 实时 预览 效果 
所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “窗口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 


在 本 例 中 我 们 选择 重复 5 条 记录 。 若 想 要 修改 服务 器 行为 的 设置 ， 则 可 以 通过 双击 该 服务 
器 行为 来 进行 ， 如 图 3-38 所 示 。 


二 三】 文档 类 型: PIP 
记录 集 Rsdb) 


重复 区 域 Rsdb) 
动态 文本 (Rsdb. ID) 
动态 文本 Rsdb. name) 
动态 文本 (Rsdb. age) 
动态 文本 (Rsdb. Result) 


图 3-38 服务 器 行为 面板 
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A 


将 页 面 切换 到 “代码 ”视图 ， 在 套用 了 “重复 区 域 ”服务 器 行为 后 ， 在 程序 代码 当中 
的 变化 便 是 这 行 单元 格 的 上 下 被 “do..….while ”循环 包围 了 , 而 重复 的 条 件 为 第 84 行 语句 (如 
图 3-39 所 示 ) ， 用 这 样 的 循环 可 以 达到 将 记录 集中 的 记录 全 部 输出 才 停止 循环 。 


Dw 文人 虽 。 靖 且 日， 二 百 (V)， 括 XD 售 KIM) 六 KX(0) 疝 信 站 这 (S| 宣 D(W) 帮 动 (H) 


重 丰 区 域 Gerat) 
动态 文本 hedh. In) 
动态 文 太 ksah nane) 
动态 文 友 Gedh age) 
动态 广 太 (hsdlh, Resalt) 


<table width=n6ee" border="1" align="center" ceLLpadding="lw cellspacing="1"> 


" [第 -页 ]</td> 
<td width 2 莉 - 页] /td> 
一 页 ]v/cd> 
<td width= aan, [最 后 一 页 ]</td> 
</tr> 
s/table> 


BI 过 操持 兰 全 是 中 
"0 时 四， 
行 mL -| TD WaT Cm 
we Xl 标题 四 加 


图 3-39 循环 语句 


在 建立 记录 集 时 我 们 就 知道 有 10 条 记录 都 在 记录 集中 ， 可 是 在 这 里 怎么 显示 了 5 条 记 
录 呢 ? 回头 来 检查 下 代码 ， 如 图 3-40 所 示 。 


DW SHID MS ND PE TO ER R00 
indecphpy x 


OE webcom php 


} 


动态 文本 (Rsib.Resuit) 


t_Redb, $vebconn) or die(mysql_error()); 
$row_Rsdb = nysql_fetch_assoc($Rsdb); 


放 (1sset($_GET['totatRows_Rsdb'])) { 
S$totalRows_Rsdb = $_GET['totaLRows_Rsdb']; 
] etse 工 
SatL_Rsdb = mysqt_query(squery_Rsdb) 
StotaLRows_Rsdb = mysql_num_rows($all_Rsdb); 
} 
S$totalpages_Redb = ceil($totalRows_Redb/Smaxaous_Rsdb)-13 


<1DOCTYPE htnt PUBLIC "-//W3C//DTD XHTNL 1.6 Transitionat//EN" 


i£ (fenetion esicts ("GatsQLVad eatring)) { 
fnetion GetS6lyalusString 虞 teyalae， 和 名 heTyoe，StheDefizeayalue = “Stheliethefinedy ve = *") 


if (PH VERSIOR <6) { 
Stheyiloe = get_nsgie_quores_ pe0 ? stripslashes Gtheyalue) : Stheralne 


图 3-40 代码 窗口 


发 现 数据 库 查询 语句 被 改写 过 ， 在 第 各 行 变量 $query_rsdb 所 用 的 SQL 语 句 是 以 前 介绍 
过 的 ， 但 在 第 43 行 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 。 
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$query limit rsdb = sprintf("%s LIMIT %d, %d", S$query_ rsdb, 
$startRow rsdb, $maxRows rsdb); 

由 上 述 代码 可 知 ，%s 表 示 字 符 串 ， 后 面 两 个 %d 表 示 数 值 ， 所 要 代入 的 值 是 
S$startRow_rsdb 与 SmaxRows_rsdb。S$maxRows_rsdb 这 个 变量 值 与 我 们 前 面 在 重复 区 域 所 选 
择 的 重复 5 条 记录 是 同步 的 ， 可 以 看 到 第 34 行 定义 了 这 个 变量 的 值 。 


SmaxRows_rsdb = 5; 


可 以 知道 ，Dreamweaver 使 用 了 一 堆 变量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 ， 然 
后 使 用 LIMIT 子 句 来 做 到 一 次 显示 指定 条 数 的 记录 。 


-334 记录 集 的 分 页 
上 一 节 已 经 可 以 浏览 记录 集中 第 1 一 5 条 记录 了 ， 那 剩 下 的 记录 如 何 显示 出 来 呢 ? 下 面 
就 介绍 记录 集 分 页 功能 的 实现 方法 。 


加 在 页 面 下 方 加 上 1x4 的 表格 ， 接 着 在 单元 格 中 分 别 输入 [第 一 页 ]、[ 前 一 页 ]、[ 下 一 
页 ]、[ 最 后 一 页 ] 的 文字 ， 使 用 鼠标 选取 [第 一 页 ]， 然 后 在 “服务 器 行为 ”面板 单 击 “+” 按 
钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-41 所 示 。 


[人 mm- OL-lel x 


PHP 动 坊 系 统 


| 
匿 EE EE TT 
(Rsdb name} Raabase) Ce 


| 只 一 而 Tm- 


图 3-41 设置 为 “ 移 至 第 一 页 
在 弹出 的 对 话 框 中 选择 记录 集 ， 以 及 确认 链接 所 选 的 范围 ， 如 图 3-42 所 示 。 


图 3-42 设置 “ 移 至 第 一 页 ”对 话 框 


分 别 为 [前 一 页 ]、[ 下 一 页 ]、[ 最 后 一 页 ] 套 用 “ 移 至 上 一 页 ”、“ 移 至 下 一 页 ”、 
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“ 移 至 最 后 一 页 ”的 服务 器 行为 。 然 后 按键 盘 上 的 F12 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 
图 3-43 所 示 。 在 页 面 中 测试 刚刚 完成 的 导航 条 ， 可 以 看 到 网 址 后 面 加 了 pageNum_dbrs 与 
totalRows_dbrs 两 个 URL 变 量 ， 它 们 被 用 来 在 分 页 浏览 时 与 重复 区 域 服务 器 行为 相 搭配 。 


世 王 古河 
A 
[hepaz7 00. Uohpweb/inder. php?psgeNum Rsdb=iatotalfows Rsdt= p> BOX vr 0 
钨 pHp 动 坊 系 统 x 


PHP 动 态 系统 


图 343 分 页 浏览 效果 
也 可 以 在 Dreamweaver 菜 单 中 执行 “插入 ”一 “数据 对 象 ”一 “记录 集 分 页 ”一 
录 集 导航 条 ”命令 来 快速 地 插入 本 范例 中 所 建立 的 记录 集 导 航 条 。 
< 555 显示 记录 计数 


在 页 面 上 方 输 入 “共有 * 笔 记录 ， 目 前 查看 第 * 笔 至 第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 
以 便 让 用 户 了 解 有 多 少 页 记录 ， 当 前 正在 浏览 第 几 页 。 


“ 记 


国 将 插入 点 置 于 “共有 ”和 “笔记 录 ” 之 间 ， 选 择 “ 服 务 器 行为 ”面板 ， 单 击 “+” 
按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “显示 记录 计数 ”一 “显示 总 记录 数 ” 选 项 ， 然 后 同样 要 
选择 记录 集 ， 如 图 3-44 所 示 。 


[7 加 
tsp <) a 


| 


DY we 
人 
Epo 坊 系 统 


图 344 显示 总 记录 数 


按 同 样 的 方式 将 插入 点 置 于 相应 位 置 ， 按 顺序 加 入 “显示 起 始 记 录 编 号 ”及 “ 显 
示 结 束 记 录 编 号 ”， 完 成 后 页 面 如 图 3-45 所 示 。 
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图 345 加 入 统计 记录 


完成 后 ， 当 我 们 浏览 该 网 页 时 便 会 出 现 当前 共有 几 笔 记录 ， 目 前 查看 的 是 第 几 笔 到 第 
几 笔 的 提示 文字 ， 如 图 3-46 所 示 。 


图 3-46 建立 导航 条 效果 


也 可 以 在 Dreamweaver 菜 单 中 执行 “插入 ”一 “数据 对 象 ”一 “显示 记录 计数 ”一 “ 记 
录 集 导航 状态 ”命令 来 快速 地 插入 本 例 中 所 建立 记录 集 导航 条 。 


如 果 打开 的 是 首页 ， 那 么 “第 一 页 ”与 “前 一 页 ”的 文字 链接 是 没有 意义 的 。 下 面 我 
们 就 来 处 理 这 个 问题 ， 当 不 是 第 一 页 时 ， 显 示 “[ 第 一 页 ]” 与 “[ 前 一 页 ]”。 当 不 是 最 后 一 
页 时 ， 显 示 “[ 下 一 页 ]” 与 “[ 最 后 一 页 ]”。 

实现 的 步骤 如 下 : 


选择 [第 一 页 ]， 在 “服务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选 
择 “ 显 示 区 域 ”一 “如 果 不 是 第 一 页 则 显示 ”选项 (如 图 3-47 所 示 ) ， 打 开 “ 如 果 不 是 第 
一 页 则 显示 ”对 话 框 ， 选 择 “ 记 录 集 ”rsdb， 再 单 击 “确定 ”按钮 ， 然 后 为 [前 一 页 ] 也 做 
同样 的 设置 ， 完 成 设置 。 
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图 3-47 选择 “如 果 不 是 第 一 页 则 显示 ”选项 


加 选取 [下 一 页 ] 链 接 文字 ， 在 “服务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 
“如 果 不 是 最 后 一 页 则 显示 ”选项 ， 如 图 3-48 所 示 。 然 后 为 [最 


菜单 中 选择 “显示 区 域 ” 
后 页 ] 也 做 同样 的 设置 ， 选 择 的 命令 为 “如 果 是 最 后 一 页 则 显示 ”命令 。 
EE Toa 


DW xe em em EMD aim Wt) el aly wDW we 


RL Lm NE rit 
PHPD 矶 系统 


re 记录 ， | 


Ee 
图 3-48 设置 “如 果 不 是 最 后 一 页 则 显示 ” 
加 完成 后 在 每 个 套用 “显示 区 域 ”服务 器 行为 的 部 分 会 出 现 “ 如 果 符合 此 条 件 则 显 


示 ” 的 提示 文字 ， 如 图 3-49 所 示 。 


PH 坟 扩 
人 sdb Teccme] 窟 记录 ， 卓 前 看 第 但 Freon 届 尘 和 全 Lacaedl 守 
县 Ke ] 


图 3-49 套用 显示 区 域 效果 


最 后 按 下 F12 键 在 浏览 器 中 检查 输出 结果 ， 如 图 3-50 所 示 
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A 图 3-50 设置 显示 区 域 后 的 效果 

人 DB, 

也 可 以 在 Dreamweaver 菜 单 中 执行 “插入 ”一 “数据 对 象 ”一 “记录 和 集 (Recordset) 分 页 ”一 
“记录 集 导航 条 ”命令 来 快速 地 插入 一 个 分 页 区 域 。 


357) 旺 示 详细 信息 


通常 一 个 动态 网 站 的 数据 量 是 比较 大 的 ， 在 很 多 时 候 并 不 会 一 开始 就 将 数据 库 所 有 字 
段 、 记 录 都 显示 出 来 。 例 如 一 个 新 闻 系 统 ， 在 首页 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 
新 闻 内 容 需 要 选择 标题 后 进入 到 另 一 个 页 面 才 能 显示 。 假 设 显示 新 闻 标 题 的 页 面 是 
index.php， 而 显示 详细 新 闻 内 容 的 网 页 名 称 为 detaiLphp。 当 在 index.php 中 单 击 标题 的 链接 
后 ， 此 时 该 超 链 接 会 带 着 一 个 参数 到 detail.php， 网 址 类 似 于 detail.php?ID=1。 多 出 的 ID=1 
是 一 个 变量 名 为 ID， 值 为 1 的 URL 参 数 。 当 detail.php 收 到 ID=1 的 URL 参 数 后 ,便利 用 这 个 
URL 参 数 在 建立 记录 集 时 筛选 所 指定 的 新 闻 记 录 ， 并 将 记录 详细 信息 显示 在 网 页 上 。 这 样 
就 构成 了 一 个 简单 的 新 闻 系 统 架构 。 要 筛选 指定 的 记录 可 以 在 SQL 中 使 用 WHERE 子 句 ， 
在 Dreamweaver 中 有 相应 的 图 形 界面 可 以 方便 使 用 。 下 面 我 们 来 看 看 Dreamweaver 是 如 何 运 
用 传送 与 接收 URL 参 数 来 筛选 出 指定 的 记录 。 


加 使 用 Dreamweaver 创 建 一 个 空白 detail.php 页 面 并 保存 。index.php 中 选择 要 用 来 连 
接 到 详细 信息 页 面 的 部 分 ( 其 实 就 是 选择 要 在 哪里 建立 超级 链接 ) ， 在 本 例 中 选择 序号 ， 
即 选择 {rsdb.ID} 动 态 文字 ， 如 图 3-51 所 示 。 


PHP 动态 系统 


图 3-51 选中 动态 文字 {rsdb.ID} 


在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文 件 ” 图 标 | 加 |， 如 
图 3-52 所 示 。 
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= SN epD。 
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《人 yw] 粘 式 9 [无 司 并 | 无 本 | 下 这 生 具 标题 fr) 
本 cs zm 车 园 攻 :了 人 有、 上 名 
国 单元 格 。 水平 思 | 陵 人 当 | 宽 名 | | 不 执行) 门 。 青 景 红色 (6) 三 -| [RAPE [页 而 证 让 
一 已 交 各 RA | 高 0| 标题 中) 口 


图 3-52 ”建立 链接 设置 
在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 detaiLphp， 如 图 3-53 所 示 。 


加 二 二 Ff indexphp 20117/301026 。 PHP 文件 5KB 
直下 
两 EL 
ET LS 
© i D) 
= Ea Ed 
nT 拓 络 日 
SHEN seeiehp ~ [ms 3 


图 3-53 设置 链接 的 文件 


如 果 只 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 并 没有 附带 URL 参 数 ， 因 此 要 设置 超级 
链接 要 附带 的 URL 参 数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 ID， 接 收 前 一 页 传递 过 来 的 ID 


值 。 
地 址 变 成 detail.php?ID=<?php echo $row_ rsdb['ITD']; ?>， 如 图 3-54 所 示 。 
pe 
格式 到 ) 无 所 美 | 无 ~ BT 三 导 二 二 标本 D[ | 
全 DD 元。 二 扫 0) Fore cy 。 昌 标 @) 总 
加 单元 格 ”水 平 岂 也。 吕 寅 曙 [ | 不 执行 门 再 ReGCiF | [GE 
DK 二 WK J 高 D[ ”| 标题 加 ) 口 


图 3-54 ”完成 后 的 链接 地 址 


网 设置 完成 后 ， 可 以 在 浏览 器 打开 index 页 面 。 在 IE 底下 的 状态 栏 上 可 以 看 到 每 一 条 
记录 的 链接 都 带 着 URL 参 数 ID， 其 值 是 每 条 记录 的 ID， 如 图 3-55 所 示 。 


二 npy/lz70DJVphpwebyindexphp 


PHP 动态 系统 


共有 11 笔记 录 ， 目 前 查看 第 1 笔 至 第 ; 笔 
站 名 年 办 


| R 村 | 
1 [ testl 21 100 
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图 3-55 单 击 链接 的 属性 显示 


避 和 六 


第 3 章 “全 程 实例 一 : 成绩 查询 系统 ， 


前 面 已 经 完成 index.php 页 面 的 制作 ， 下 面 来 设计 接收 URL 参 数 的 detail.php 页 面 ， 看 看 
如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 

贺 打开 detailLphp 页 面 后 选择 “ 绑 定 ”面板 ， 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选 
择 “ 记 录 集 (查询 ) ”选项 ， 如 图 3-56 所 示 。 


图 3-56 选择 “记录 集 (查询 ) “ 
在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
@ 在 “名 称 ” 文本 框 中 输入 rsdetail 作 为 该 “记录 集 ” 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 选择 webconn 选 项 连接 对 象 。 
@ 从 “表格 ”下 拉 列 表 框 中 选择 使 用 的 数据 库 表 对 象 为 websql。 
@ 在 “ 列 ” 选 项 区 选中 “全 部 ” 单 选 按钮 。 
@ 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参 数 /ID。 
完成 后 的 设置 如 图 3-57 所 示 。 


和 ee 
名 称 : 
连接 :| webeonn 四 
表格 -| websql 四 
列 : 回 全 部 “日 选 定 的 
网 


攻 
四 
EE 


图 3-57 设置 rsdetail 记录 集 

如 果 想 知道 SQL 语 句 ， 可 以 单 击 “ 高 级 ”按钮 。 在 “高 级 ”界面 检视 QL 语句 ， 
如 图 3-58 所 示 。 在 SQL 语句 中 的 colname 是 一 个 变量 ， 若 筛选 的 时 候 有 用 到 变量 ， 
Dreamweaver 就 会 用 这 个 变量 名 称 放 在 SQL 语 名 里， 而 这 个 变量 的 值 会 是 什么 呢 ? 就 是 下 
面 “ 变 量 ” 区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运作 时 ，colname 将 等 于 URL 变 量 ID 的 
值 ($_GET[ID']) ， 所 以 当 URL 变 量 ID 值 不 同 ， 簿 选 出 的 结果 也 不 同 。 


- 115 - 


Sche 网 站 开 舌 全 程 实例 (第 2 版 ) 


图 3-58 ”高 级 “记录 集 ” 对 话 框 
贺 然后 单 击 “ 确 定 ”按钮 完成 记录 集 建立 。 记 录 集 建立 完毕 后 ,可 以 把 各 个 字段 “ 插 
入 ”到 页 面 上 相应 的 单元 格 中 ， 如 图 3-59 所 示 。 


DW 十 ， 国 0LIelxj] 
a por 


语 - 一 汪 | 
[deailiD} lirsdelname) rdealage | tedeaiReskj| 更 厅 /8 | 


| 着 | 元 -BI 语 拓 替 扫 4D) | 
CE “OB ea 一 
-wm FP Was CE 
了 sm 一 


标 生 G) 
图 3-59 制作 的 详细 页 面 


完成 后 直接 按 F12 键 在 浏览 器 中 打开 detail.php, 发 现 内 容 是 空白 的 , 如 图 3-60 所 示 。 
We 回 事 呢 ? 因为 在 网 址 后 面 没 有 带 着 URL 参 数 ， 当 然 记 录 集 里 就 不 会 有 任何 东西 。 


El Ti 


< 商 hop/27 00 Vphpwmb/ dts Php pacx|EE 
[Sa | 
了 HP 动态 系统 
Ea E23 [EE EE 全 村 
| | | | 硬 攻 /光标 


图 3-60 显示 为 空白 
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8@° 


直接 在 网 址 后 加 上 URL 变 量 ID， 其 值 可 以 选 1 ~ 10 的 任何 一 个 值 ， 如 这 里 输入 6， 
然后 按 Enter 键 ， 网 页 显示 的 结果 如 图 3-61 所 示 。 


人 ET | 
| hapy127001/phpwepjdemiphp7rD=6 D2 Bx) ries 
2] " [eel < — 


PHP 动 态 系统 
阵 圳 年 徐 世 河 下 
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图 3-61 URL 参数 1D=5 时 的 详细 页 面 
在 index.php 中 ， 每 一 笔记 录 的 网 址 都 带 有 特定 的 参数 链接 到 detail.php， 如 图 3-62 


所 示 。 
hb Er 
|[@ retes/127.00. Vphpweb/incer phoipageNum Redo=18actalRows Rsdb=: P - SO x nl roe 
3 ~ ml i E 


: 
图 3-62 单 击 编 号 链接 
单 击 第 10 个 链接 后 ， 打 开 指定 记录 的 详细 页 面 ， 如 图 3-63 所 示 。 


: 这 里 如 果 不 以 编号 做 为 主 链接 也 是 可 以 的 ， 像 我 们 经 常 使 用 到 的 标题 ， 即 单 击 某 个 新 闻 标题 ， 
; 即 可 以 打开 相应 的 详细 页 面 采用 的 就 是 这 种 技术 。 
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) 3.4 编辑 记录 集 


数据 库 记 录 在 页 面 上 的 显示 ， 重复 , 分 页 计数 ， 显 示 详 细 信 息 的 操作 已 经 介绍 完毕 ， 
本 小 节 将 介绍 在 Dreamweaver 中 进行 增加 、 修 改 以 及 删除 记录 的 操作 。 


341) 增加 记录 功能 
在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 且 附 加 了 “自动 编号 ”属性 ， 因 此 在 


新 增 记 录 时 不 必 考 虑 ID 字段 ， 只 需 增 加 3 个 值 即 可 。 
实现 的 步骤 如 下 : 


创建 一 个 空白 的 php 网 页 ， 并 命名 为 add.php， 先 添加 一 个 表单 ， 再 插入 一 个 4x2 表 
格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-64 所 示 。 
De 珊 : BB Ol-lol x*] 
7 @. 4 Ee ee 
PHP 动 态 系统 
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[UD te fe tos ee 
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[om 机 中 下 了 - BI 过招 壮 工 村 是 0 
有 css ITO) Fesult ~， -OQ 9) 
EE Tl | 


一 将 二 W 基 A 而 0 祭 题 Q) 本 
图 3-64 ”建立 表单 并 设计 网 页 

当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必须 置 于 表单 内 ， 在 单 
击 按钮 后 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。Dreamweaver 中 的 新 增 、 更 
新 记录 都 是 将 表单 元 素 的 值 以 POST 的 方式 传递 给 页 面 ， 当 程序 判断 到 指定 字段 〈 新 增 记 
录 时 字段 名 为 MM_insert， 当 使 用 了 “插入 记录 ”服务 器 行为 时 该 字段 将 被 自动 添加 ) 送 
出 了 POST 信息 《〈 值 为 窗 体 名 称 ) ， 便 执行 新 增 、 更 新 记录 等 部 分 的 程序 。 

贺 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 并 在 “属性 ”面板 为 其 命名 ， 分 别 
是 姓名 name、 年 龄 age、 成 绩 Result, 注意 在 设计 时 要 与 记录 集 字段 名 称 一 一 对 应 ， 如 图 3-65 
所 示 。 


Name Result Class 无 - See Vabe 多 Tite 


Text 


口 peabed TReqred TAutoComplete Fom patem 
口 AutoFoas TReadonly 


图 3-65 命名 文本 域 
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; 当 表 单元 素 的 命名 与 记录 集 字段 相符 合 时 ， 在 做 “新 增 记录 ”、“ 更 新 记录 ”时 Dreamweaver 
会 自动 将 表单 元 素 与 记录 集 字段 相 瑟 配 。 


打开 < 服务 器 行为 ” 面板 ， 单 击 。 < ” 接 钴 ， 从 弹出 的 下 拉 菜 单 中 选择 < 插入 记录 ， 
命令 ， we 


DW x4ln) mike EE HAD SatM Wo) Ps) “as) ECIW) Bo) 王国 0OLIoLx] 


图 3-66 执行 “插入 记录 ”命令 
打开 “插入 记录 ”对 话 框 ， 设 置 插入 记录 属性 ， 选 择 连接 为 webconn， 插 入 表格 
至 websql， 这 是 要 设置 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 表 后 ，“ 列 ”区 域 中 
便 会 出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 表 字段 要 从 表单 中 的 哪个 元 素 
获取 值 ， 具 体 的 设置 如 图 3-67 所 示 。 


播 入 记录 


提交 值 ， 自 : [fornl 


图 3-67 设置 “插入 记录 ”对 话 框 
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之 前 将 表单 元 素 的 名 称 命名 为 与 数据 库 字 段 名称 相 同 , 所 以 在 建立 “插入 记录 ”时 , Dreamweaver 
便 会 自动 将 它们 配对 。 也 可 以 先 选择 欲 设置 的 字段 ， 由 “ 值 ” 右 方 的 下 拉 式 菜单 中 选择 从 哪个 
表单 元 素 取 得 值 。 然 后 在 “插入 后 ， 转 到 ”的 文本 字段 框 填 上 index.php。 将 表单 元 素 的 名 称 与 
数据 库 内 的 字段 名 称 命名 为 相同 ， 除 了 “插入 记录 ”以 外 ，“ 更 新 记录 ”服务 器 行为 也 会 将 相 
同名 称 的 数据 列 与 表单 元 素 自动 地 配对 在 一 起 。 


设置 完成 后 ， 在 “服务 器 行为 ”面板 的 列表 中 就 会 多 出 一 项 插入 记录 ( 如 图 3-68 
所 示 ) ， 可 以 双击 该 项 重新 进行 “插入 记录 ”的 设置 。 完 成 后 网 页 上 的 表格 会 变 成 浅 绿色 
的 底 ， 当 然 这 并 不 是 表示 有 错误 ， 而 是 让 我 们 知道 该 表单 使 用 了 “服务 器 行为 ”。 在 表单 
内 也 自动 加 上 了 隐藏 字段 名 称 为 MM_insert， 用 来 判断 用 户 是 否 单 击 “ 提 交 ” 按 钮 送出 信 
息 ， 和 是 否 执行 “插入 记录 ”部 分 的 程序 代码 。 


DW znn sun wi EAm we We) Sc Mais BOW smon 
ap > Er Erm 
NE wenn ne 

EE Ei 


图 3-68 插入 记录 后 的 页 面 效果 


国 直接 按 F12 键 在 浏览 器 中 打开 网 页 ， 输入 值 如 图 3-69 所 示 ， 单 击 “提交 ”按钮 尝试 
新 增 一 笔记 录 。 


| mewazroouphpwebladdchp 


图 3-69 输入 记录 数据 


单 击 “ 提 交 ” 按 钮 后 ， 网 址 将 从 add.php 转 至 index.php。 单 击 网 页 下 方 的 分 页 导航 
条 的 “最 后 一 页 ”链接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-70 所 示 。 
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PHP 动 态 系 统 


共有 11 笔记 录 ， 目 前 查看 第 11 竺 至 党 11 笔 
下 名 ] 只 


图 3-70 “增加 记录 后 的 效果 
简单 看 看 这 部 分 的 程序 代码 是 怎样 的 。 表 单 的 "动作 "为 <?php echo $editFormAction; ?>， 在 单 
击 按钮 后 网 页 是 将 信息 以 POST 的 方式 送 给 自己 ， 所 以 先 记 住 这 个 变量 后 切换 至 “代码 ” 
视图 ， 可 以 看 到 $editFormAction 变 量 的 值 如 图 3-71 所 示 ，$_SERVER 是 预定 义 变量 的 一 种 ， 
用 以 提供 服务 器 的 相关 信息 ;而 $_SERVER['PHP_SELF'] 便 是 返回 该 网 页 的 文件 名 称 。 所 
以 ， 表 单 的 "动作 "为 <?php echo $editFormAction; ?> 就 意味 着 将 表单 数据 以 POST 的 方式 传 
递 给 本 身 。 


php echo SeditPormAction; ?> 已 目标 0) 8 


动作 
方法 |PosT Y 编码 交 型 


图 3-71 表单 动作 参数 
接着 看 到 被 自动 添加 的 隐藏 字段 MM_insert， 其 值 是 form1， 与 所 在 位 置 的 表单 名 称 一 
致 ， 代 码 的 窗口 如 图 3-72 所 示 。 


Dw sen wa a MN BSIM 和 IO SO els) NW mm mw. BB ol-lel x 


EY rer tts 
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图 3-72 代码 窗口 


核心 的 代码 说 明 如 下 : 

if ((isset($ POST["MM insert"])) && ($_POST["MM insert"] == "forml")) 
{ 

// 判 断 表单 变量 $_POST[ 'MM_insert'] 是 否 被 设置 ， 且 值 是 否 等 于 form1l1， 若 是 ， 则 执行 


下 面 的 插入 记录 动作 。 
$insertSQL = sprintf ("INSERT INTO websql (name, num, `Price `) VALUES 


ME PN 
// 定 义 了 SQL 语句 。 
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GetSsQLValueString($ POST['name'], “text"), 
GetSQLValueString($ POST['num'], "int"), 
GetSQLValueString($ POST['Price'], "text")); 


// 取 值 表 单 的 变量 。 

mysql _ select db($database webconn, S$webconn); 

$Resultl1 = mysql query($insertSQL, $webconn) or die(mysql error()); 
// 连 接 数 据 库 执行 SQL 语 句 。 


$insertGoTo = "index.php"; 


// 设 置 了 在 "插入 记录 "后 要 跳 转 的 文件 index .php， 它 被 存储 在 变量 $insertGoTo 中 。 


< 342 更 新 记录 功能 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根据 需要 进行 更 新 的 操作 。 这 里 我 们 会 用 前 面 
已 经 使 用 到 的 detail.php 文 件 。 


更 新 记录 功能 的 操作 步骤 如 下 : 
加 打开 detail.php 网 页 后 ， 选 择 链接 文字 “更 新 ”， 如 图 3-73 所 示 。 
DW zn wa 3 NO am wa) se we er sel 而 - 面 5l=leLzJ 


evden ID) (evdend name) [frsderal oame) (rdersd Remt} 


Ea 
ma 人 四 天 入 下 EE 


Bs mt 人 中 -Bm 
PT em | 
国 : re 村 四 已 


图 3-73 选择 链接 文字 


贺 在 “属性 ”面板 中 单 击 如 图 3-74 所 示 的 浏览 文件 图 标 ， 为 其 建立 附带 URL 参 数 的 
超级 链接 。 


属性 
[<《> mL| 格式) 无 ~ 类 | 无 vBI 汪汪 绍 旨 标题 r) 
Bbcss 五 四 无 ~ 链接 0 YOR EO 
下 单元 格 。 水 平 Z) 默认 YY 宽 D) 不 执行 0) 口 。 青 景 若 色 (6) 厂 -| 

| 局 


口 北 一 一 标题 EE) 口 ] 
图 3-74 单 击 “浏览 文件 ”图 标 
加 输入 用 来 更 新 记录 使 用 的 update.php 页 面 ,为 其 建立 名 称 为 ID、 值 是 rsdetail 记 录 集 
ID 字段 值 的 URL 参 数 。 
加 完成 后 的 链接 地 址 : 


update.php?ID=<?php echo $row_rsdetail['ID']; ?>// 传 递 ID 到 update.php 页 
面 ， 如 图 3-75 所 示 。 


- 122 - 


第 3 章 全 程 实例 一 : 成 绩 查询 系统 @ 
@ ® 


[yamc] | 格式 四 | 无 加 类 | 无 vBI 二 和 上 旺 本 OD 

css WD[ 玩 司 放 四 jayaate pip7D-GHs eh 名 局。 目标 加 二 

四 全 水平 四 国人。 加 | 寅 TWO WRNEGE | [CAERE 
DE 天 四 了 OD 


图 3-75 传递 ID 至 update.php 
创建 update.php 空 白文 档 ， 该 页 面 的 设计 与 详细 信息 页 面 detail.php 相 同 ， 都 是 要 利 
用 接收 到 的 URL 参 数 筛 选 指定 记录 。 在 “服务 器 行为 ”面板 中 ， 单 击 “+” 按 钮 ， 从 弹出 
的 下 拉 菜 单 中 选择 “记录 集 ”， 如 图 3-76 所 示 。 


Dw sn wan gEm 区 aM 本 ae ae nm sm 


EBD 


图 3-76 选择 记录 集 
国 则 会 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 


@ 在 “名 称 ” 文本 框 中 输入 rsupdate 作 为 该 “记录 集 ” 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连 接 对 象 。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
@ 在 “ 列 ” 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 

@ 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参 数 /ID。 
完成 后 的 设置 如 图 3-77 所 示 。 


记录 条 
名 称 : rsupdate | [| 
ee Ew | EE 
表格 -wabsal = | = 

列 : 加 全 部 ， 个 先 定 的 : 二 
nD | 
ee 
IResult 
节选 : | 功 ao] 车 
VEL 参数 aE: 
| 排序 : 殉 四 | 升序 


图 3-77 设置 “记录 集 ” 对 话 框 
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将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 按 钮 设置 完成 ， 在 “ 绑 定 ”面板 中 将 记录 集 
内 的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 如 图 3-78 所 示 。 


Dw 文 HR 疙 有 日 ” 坦 大 Vi， 项 和 四。 修改 (M) 首 &(O| 人 S(O ”区 吉 S) 吝 D(W 才 3b(H 瑚 -. 园 OL= 9 >* 
人 | 拓 夫 机 + | 著 招 图。 从。 椒 :更 3 面 
update.php” Xx 
IE ebcom rtp 
ee 如 rame 
序 S ee 
[rupaate. | |irswpamenane] [icedare.agel | | irsupdate.Resul] a 
二 ERIE 了 
| 目 目 国 5， av 
二 
《ynEL| 格式 m) [无 -| 类 无 - BI 3 招 闪 扫 本 omC |] 
BGs Da aaa 一 姑 扩 0 -OB BF 
吕 王 | 单元 格 。 水 平 包 )[ 跌 认 ] 克明 | 不 换行 由 口 倘 录 灰色 05) 厂 -| J 
一 总 其 天 ODNA 7 高 标量 四 站 
图 3-78 绑 定 字段 


国 由 于 ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 击 选择 
文本 字段 ， 如 图 3-79 所 示 。 


Dw 交 从 将， 豆 玉 V】 拍 和 () 侈 (IM) ERIO 全 OQ。” 辣 (5) 四 COW 让 (| Bm. 6 OL-lel x 


re] | rem ee 
置 


remdate. nanel 
区 


Soe [te | | abe [Gyre com irol 


mT 


petem i 


Nome 1m | cess 无 a 
Piece Hoer 


oad Tineqied Tatocerite Fam 
Dabrons Rew 


EE 有害 ] 


图 3-79 设置 “编辑 标签” 命令 
国 在 “属性 ”面板 中 ， 选 中 “Read Only (只 读 ) ” 复 选 框 ， 如 图 3-80 所 示 。 通 过 这 
样 的 设置 ， 这 个 字段 便 不 能 被 用 户 修改 。 


ds 
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尾 性 
Ei Name TD Gass 无 所 Size 1 || We Crhp echo ro 到 Tite 
MaxLength Place Holder 
[Doisabled Requred AutoComplete Fom ~ Patten Tab Index List 
DautoFoms resd ory 


图 3-80 设置 为 “只 读 ”属性 


在 “服务 器 行为 ”面板 中 单 击 “+?” 按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ” 
选项 ， 如 图 3-81 所 示 。 


Dw xHm mc sa ND rr) ERIO ee(O aa BOW mt) Be | Ga OL= Lol >] 
PHP 动态 系统 
ao 了 
“也 
supuate hl | | repiate nine] [iroupdate, age] | rapaate. Rosu] js 
更 新 [重要 
， 
» 
[3 Wy Fim #fwnl WH WW 上 日 时 1 :we 
me ax -| 着 <vRqml 
tmoh | | Place Holder 
Dased peqwod Taocoiete | Fom | pen | | re 
arons Taew om 


图 3-81 执行 “更 新 记录 ”命令 


打开 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 选 择 “ 连 接 ”webconn 后 ， 每 
个 表单 元 素 与 字段 都 会 自动 匹配 好 ， 只 需 在 “在 更 新 后 ， 转 到 ”文本 框 中 输入 index.php， 
如 图 3-82 所 示 。 


值 : FoR, ID ~ 
提交 为 弄 数 | 回 主键 
在 更 新 后 , 转 到 : index. php EE 二 开 


图 3-82 设置 更 新 记录 参数 
单 击 “ 确 定 ” 按 钮 ， 完 成 后 页 面 的 表格 同样 会 被 套 上 浅 绿色 的 底 ， 而 表单 中 也 会 
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多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 名 相同 ， 如 图 3-83 所 示 。 


lol x 


| | MN De EE | 于 | 
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图 3-83 ”完成 的 页 面 效果 
最 后 在 浏览 器 中 打开 index.php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail.php， 再 在 详 
情 页 面 选择 “更 新 ”链接 ， 如 图 3-84 所 示 。 


(SS’V 人 Wd 


全 ep /27 00 Vehpwet/desitpheniD-10 Pp-acx) ow 
Et x 


图 3-84 选择 “更 新 ”链接 
在 update.php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 , 而 ID 文本 字段 是 不 能 被 修改 ， 
更 改 完成 后 单 击 “ 更 新 ”按钮 ， 如 图 3-85 所 示 。 


OB mp//127.0.0.Vphpweb/update php7iD=10 pracxloye 
EL x 


PHP 动 态 系统 
匡 区 
| 10 | 留 EE 6 
| [LE 
图 3-85 修改 数据 
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返回 到 index.php， 检 查 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-86 所 示 。 


本 [el E le | 
贸 http://127.0.0.Vphpweb/index.php?pageNum Rsdb=1atotalRows Redb-=: PD = GX) Ee 
区 PHP 吉 坟 至 统 * [mm = 
PHP 动 志 系统 
共有 10 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
斥 号 | 姓名 I 年 苍 成 绩 
6 | test6 I 21 | 66 
了 | test7 22 955 | 
3 | testS 23 87 
2 [ test9 24 69 
10 test10 23 四 
= [ie 加 


图 386 完成 更 新 的 功能 页 面 
这 部 分 的 程序 代码 与 插入 记录 基本 相同 ， 差 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 使 用 的 是 
UPDATE 语 句 o 


-5343 ) 删 除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ” 命 
令 即 可 以 实现 。 

具体 的 实现 步骤 如 下 : 

加 使 用 超级 链接 带 着 URL 参 数 转 到 删除 页 面 del.php, 首先 在 detail.php 中 选中 “删除 ”， 
在 “属性 ”面板 中 建立 链接 ， 如 图 3-87 所 示 。 


DW xptp wi lv A) Sw(M) (0) S41 sl) OW) RAH) Ba-. Ey ol-lol *] 


yan 首开 中 [于 J -BJ 污 汪 汪汪 4 
cs | mm 无 WM -Oa 
EJ me | ] de ， 
一 开罗 OA -| 商 明 | 本 焉 品 本 “ 工 个 二 下 析 二 和 ,总共 BE 过 


图 3-87 设置 “删除 ”链接 
因为 删除 记录 还 是 依据 主键 的 ID 字段 ， 故 选择 删除 记录 所 用 文件 deLphp， 并 附带 
URL 参 数 ， 其 名 称 为 ID， 值 为 rsdetail 记 录 集 的 ID 字段 值 ， 如 图 3-88 所 示 。 


- 127 - 


文本 stetall.ID) 
tt 


到 普 文 本 frs 

2 Ct Ry 
动 坟 属性 (a re 条 ov_rstetailf TD ]) 
基本 属性 (rsf 和 ov yetetsilf DD) 


EE 
[Om ty) 无 -B 尘 尘 本 中 


| DW 元 Ss “ee rm ~ Oi = 
国 单元 格 。 水 平权 [对 认 可 机 有 | 7 筑 行 四 癌 有 及 拓 芭 6 三 | Cr 
到 LE ~ 高 9 标题 中 门 ] 


图 3-88 设置 传递 的 参数 属性 
单 击 “ 确 定 ”按钮 ， 这 样 就 完成 了 detail.php 的 修改 工作 。 创 建 del.php 文 件 ， 在 “ 绑 
定 ” 面 板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “记录 集 ”， 如 图 3-89 所 示 。 


DO Bm.| 国 0OLleL> 


| 代码 | 拆 分 设计] 


图 3-89 选择 “记录 集 ”命令 
打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 


@ 在 “名 称 ” 文本 框 中 输入 rsdel 作 为 该 “记录 集 ” 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连 接 对 象 。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
@ 在 “ 列 ” 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 
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入 
@ 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参 数 /ID。 
完成 后 的 设置 如 图 3-90 所 示 。 


图 3-90 设置 “记录 集 ” 属 性 
将 各 个 记录 集 字段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 Del， 
然后 在 “服务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ” 命 
令 ， 如 图 3-91 所 示 。 


DW f(D WE) 二 (V 手 和 ID) 仿 改 (M) 椎 K(0) 全 S(O ER(S) OCW Mah) mm- 0s 


| rsdel.nane} | | {rsdel.age] {rsdel. Result} | 


1 [rsael.T 


[PE 


《>I0NL| 。 术 式 外) [自若 上 天 
且 css I 无 草 接 中 


图 3-91 选择 “删除 记录 ”命令 
在 弹出 的 “删除 记录 ”对 话 框 中 进行 如 图 3-92 所 示 的 设置 。 
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A 


GO: di Se、 网 站 开 必 全 程 实例 (第 2 版 


加 全 全 


局 ‘ve 
Er ER 
首先 检查 是 否 已 定义 交 量 - [ 主 急 值 = ] 记 枉 | 
去 格 - [rebsa = EE 
主键 列 -| 加 "| 回 数值 
主键 什 - [号 多数 了] 耳 
遇 除 后 ， 转 到 : index. php 


图 3-92 设置 删除 记录 参数 


人 

/信人 会， 

“主键 列 ” 与 “主键 值 ”所 设置 的 是 删除 记录 的 依据 ， 这 里 的 依据 是 指 在 DELETE FROM 数据 
表 WHERE 条 件 里 的 条 件 ， 假 设 条 件 是 WHERE ID = 11， 相 应 地 ， 你 可 以 看 成 WHERE 主键 列 


= 主键 值 。 在 这 里 并 不 一 定 要 选择 数据 库 中 的 主键 来 当做 主 索引 键 字 段 。 


单 击 “确定 ”按钮 完成 设置 。 

本 章 学 习 了 最 基本 的 Dreamweaver 内 置 服务 器 行为 的 操作 和 使 用 ， 并 且 了 解 了 其 原始 
程序 代码 的 意义 。 在 后 面 的 章节 中 如 用 户 管理 系统 、 留 言 管理 系统 、 新 闻 管 理 系统 等 都 将 
用 到 这 些 基础 的 操作 。 
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第 章 


全 程 实例 二 : 用 户 管理 系统 


在 网 站 建设 开发 中 ， 第 一 个 要 接触 的 就 是 用 户 管理 系统 的 开发 ， 即 网 站 提供 给 会 员 注 
册 并 能 登录 进行 一 些 操作 的 基础 功能 。 一 个 典型 的 用 户 系 统 ， 一 般 应 该 有 用 户 注册 功能 、 
资料 修改 功能 、 取 回 密码 功能 、 及 用 户 注 销 身份 功能 等 。 本 章 将 以 前 介绍 的 知识 加 以 灵活 
应 用 。 该 实例 中 主要 用 到 了 创建 数据 库 和 数据 库 表 、 建 立 数据 源 连 接 、 建 立 记录 集 、 创 建 
各 种 动态 页 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 之 间 传 递 信息 、 创 建 导 航 条 、 隐 藏 导 
航 条 链接 等 技巧 和 方法 。 


用 户 管理 系统 网 站 结构 的 搭建 

创建 数据 库 和 数据 库 表 

建立 数据 源 连 接 

掌握 用 户 管理 系统 中 页 面 之 间 信 息 传 递 的 技巧 和 方法 
用 户 管理 系统 常用 功能 的 设计 与 实现 


网 站 开发 全 程 实例 〈 第 2 版 ? 
【 28 


有 1 4.1 用户 管理 系统 的 规划 


用 户 管理 系统 在 开发 之 前 要 做 好 整个 系统 的 规划 ， 如 在 注册 时 需要 采集 哪些 资料 ， 是 
否 提 供 在 线 修改 密码 等 等 操作 。 这 样 方便 后 面 整 个 系统 的 开发 与 制作 ， 本 小 节 就 介绍 一 下 
用 户 管理 系统 的 整体 规划 工作 。 


471) 页 面 规 划 设计 

“用 户 管理 ”的 系统 分 成 用 户 登 录入 口 与 找 回 密码 入 口 两 个 部 分 ， 其 中 index.php 是 这 
个 网 站 的 首页 。 在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CC 的 网 站 环境 按 F12 键 
来 浏览 网 页 ， 或 者 在 IE 浏览 器 输入 “http:WlocalhosVymemberindex.php” 来 打开 用 户 系 统 的 
首页 index.php， 其 中 member 为 站 点 名 。 

实例 共有 12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 功能 如 表 4-1 所 示 。 


表 4-1 用 户 管理 系统 网 页 功能 表 


页 面 功能 
index.php 用 户 开始 登录 的 页 面 
welcome.php 用 户 登录 成 功 后 显示 的 页 面 
loginfail.php 用 户 登 录 失败 后 显示 的 页 面 
register.php 新 用 户 用 来 注册 个 人 信息 的 页 面 
regok.php 新 用 户 注 册 成 功 后 显示 的 页 面 
regfail.php 新 用 户 注 册 失 败 后 显示 的 页 面 
lostpassword.php 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
showquestion.php 查询 密码 时 输入 提示 问题 的 页 面 
showpassword.php 答对 查询 密码 问题 后 显示 的 页 面 
userupdate.php 修改 用 户 资料 的 页 面 
userupdateok.php 成 功 更 新 用 户 资 料 后 显示 的 页 面 
退出 用 户 系统 的 页 面 


-492 ) 拱 建 系统 数据 库 


通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 
以 及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E-mail、 电 话 等 ， 所 以 在 数据 库 中 必须 包含 一 个 容纳 
上 述 信息 的 表 ， 称 之 为 “用 户 信息 表 ”， 将 数据 库 命名 为 member。 搭 建 的 数据 库 和 数据 表 
如 下 : 


加 在 phpmyAdmin 中 建立 数据 库 member， 单 击 选择 了 数据库 命 令 ， 打 开本 地 的 “数据 

库 ” 管理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 member， 单 击 打开 后 面 的 数 

据 库 类 型 下 拉 菜 单 ， 在 弹出 的 选择 项 中 选择 “utfg_bin” 选 项 ， 单 击 “ 创 建 ”按钮 ， 返 回 
“常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 member 的 数据 库 ， 如 图 4-1 所 示 。 
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27001 1 120700 nO 恨 
phpMyAdmin 


去 于 有 入 主持 掉 枯 风 内 -LO_OcTeIaLO ” 司 * sl: 1271001va TePIP 
~ RS bysor 
了 514 -MySaL commuray 
Sever(GPL) 


站 

® 了 | Pans 回 

#9: 国 

| ~ Nae 7 an openssin oe 
Bt em mane 


[ee 0 one dm vce pple 下 | 


图 4-1 创建 member 数据 库 


单 击 左边 的 member 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数 据 表 ”页 面 ， 输 入 数据 表 名 
member，“ 字 段 数 ” 文 本 框 中 输入 本 数据 表 的 字段 数 为 12， 表 示 将 创建 12 个 字段 来 储存 数 
据 ， 再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设置 数 
据 域 位 的 相关 数据 ， 如 图 4-2 所 示 。 


rr 
纺 12700111270011 me-* ij 
phpMyAdmin 了 
会 9 站 间 ] WE 由 sa 六 本 关 央 和 A 局 
REWER) 局 EE 
1 本 五 AUTOINCREMENT 
-+ ee] ne = 2 wemane vacial20) ua bn 可 到 
而 浊 manbe 3 Pateworg varcna20 wm_m 五 王 有 
| 一 eston wamfiol us 由 再 王 
竹器 Peer 下 ”5 answer varcha(s0) us bn 本 到 
mq 
办 peromanee_schema = 5 vuename vaicnarl50) wo_bm 下 局 
上 bn 7 sex varchar(10) WS_ bm 理 天 
二 Ce 9 ggress varcharls0) a bn 是 WULL 
计 ecam 9 en wm 是 MULL 
人 oa waz0) ste 是 WUAL 
加 em 0) ua bn 是 NULL 
Tmmomy ma) ven 否 到 > 开赴 再 只 一 Y 更 多 
t_ pF seg ME FH 0 > 王 要 而 唯 - 逢 夭 引 国字 间 
而 全 7 过 
局 11 证 唱 关系 十 知 颈 如 i 羽生 秆 庆生 后 
i Fa Fao Fo5In EL 0 了 


图 4-2 建立 member 数据 表 
各 字段 如 表 4-2 所 示 ， 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 及 
登入 的 账号 与 密码 。 


表 4-2 member 数据 表 
字段 名 称 3 字段 大 小 


ID i 
username 
password 


question varchar 
answer Varchar 答案 


truename 50 真实 姓名 


找 回 密码 提示 
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( 续 表 ) 


字段 名 称 字段 型 态 
address Varchar 
tel Varchar 


邮箱 
1 | 登录 区 分 


创建 的 数据 表 有 12 个 字段 ， 读 者 在 开发 其 他 用 户 管理 系统 的 时 候 可 以 根据 采集 用 户 信 
息 的 需要 加 入 更 多 的 字段 。 


-人 413) 用户 管 理 系统 站 点 


在 Dreamweaver CC 中 创建 一 个 “用 户 管理 系统 ”网 站 站 点 member， 由 于 这 是 PHP 数 据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-3 所 示 。 


表 4-3 ”站 点 设置 的 基本 参数 


email 


authority 


站 点 名 称 member 


MySQL 服 务 器 地 址 
管理 账号 / 密码 
数据 库 名 称 [nr | 


创建 member 站 点 具体 操作 步骤 如 下 : 


加 首先 在 C:XAMPP\htdocs 路 径 下 建立 member 文 件 夹 ( 如 图 4-3 所 示 ) ， 本 章 所 有 建 
立 的 网 页 文件 都 将 放 在 该 文件 夹 底下 .。 


图 4-3 建立 站 点 文件 夹 member 


加 运行 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 
理 站 点 ”对 话 框 ， 如 图 4-4 所 示 。 
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第 4 章 全 程 实例 二 : 用 户 管理 系统 Se 


图 44 “管理 站 点 ”对 话 框 
对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 面 的 “新 
建站 点 ”按钮 打开“ 站 点 设置 对 象 ” 对 话 框 ， enlist 


站 点 是 网 站 由 使 用 的 所 有 文件 和 交 源 的 人 


er 


您 司 以 在 此 处 为 Dreamwzaver 站 点 选择 本 地 文件 夹 和 名 称 " 
让 点 名 称 : [memoer 


图 4-5 ee 
单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 j， 打 开 “ 基 本 ” 


选项 卡 进行 如 图 4-6 所 示 的 参数 设置 。 


| 一 日 
质 SA 和 ai | 
> 活检 方法 : [下 了 
服务 器 文件 赤 : [Cyanpphocs Ss 
WIREeaaaxe | | 
| [mE | > | 
证 末 一] [mn 忆 商 


图 46 “基本 ”选项 卡 设置 
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设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 表 示 是 使 用 PHP 开 发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-7 所 示 。 


| 


思维 护 同 步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 启用 文件 取出 功能 

区 打开 文件 之 前 取出 


图 4-7 设置 “高 级 ”选项 卡 
国 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 图 4-8 所 


| 一遍 | 您 将 在 此 位 轩 反 加 web 上 的 而 而 的 了 务 器 。 此 对 话 框 的 设置 下 
nternet 服务 提供 (SP) 或 Web 管理 只 
* 高 级 设置 


a 您 无 需 完成 此 步 邓 。 如 果 要 连接 到 Wb 并 发 


图 4-8 设置 “服务 器 ”参数 


单 击 “ 保 存 ” 按 钮 ， 即 可 完成 站 点 的 定义 设置 ， 在 Dreamweaver CC 中 就 已 经 拥有 
和 ep et het 单 击 “完成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 
村 Dreamweaver CC 测试 用 户 管理 系统 网 页 的 网 站 环境 设置 。 


< 设置 数据 库 连 接 
完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 
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的 连接 设置 如 下 : 
加 将 本 实例 的 静态 文件 复制 到 站 点 文件 夹 下 ， 打 开 index.php 网 页 ， 如 图 4-9 所 示 。 


Dw xsln sa EEV) EN Pa) Et(Ol S(O Wals| ECW mH Bm-. B30 
ndexphp x em Oe CVA dv in i 


ais 
用 户 注册 资料 修改 


图 4-9 打开 index.php 网 页 
单 击 菜单 栏 上 的 “窗口 ” 一 “数据 库 ” 命令， 打开 “数据库” 面板 。 在“ 数据库” 
面板 中 单 击 “+” 图 标 ， 并 在 打开 的 下 拉 菜 单 中 选择 “MySQL 连接 ” 选项， 如 图 4-10 所 示 。 


图 4-10 选择 “MySQL 连接 “ 

在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 mymember、“MySQL 服 务 
器 ”名 为 localhost、 “用户 名 ”为 root、 密 码 为 admin。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 
可 以 单 击 “ 选 取 ” 按 钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 ， 选 择 刚 导入 的 范例 数据 库 
member， 如 图 4-11 所 示 。 


连接 名 称 : hynenber 
MySQL 服务 器 : 1ocalhost 
用 户 名 : root 


图 4-11 设置 MySQL 连接 参数 
辆 单 志 “测试 ” 按 钮 ， 测 试 与 MySQL 数 据 库 的 连接 是 否 正确 ， 如 果 正 确 ， 则 弹出 一 
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图 4-12 设置 成 功 
单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数 
据 库 ， 如 图 4-13 所 示 。 


| 


日 国 mymenber 
日 -七 


address (varchar 50; 
answer (varchar 50 4 
authority (char 1 必 
email (varchar 50) 
功 (int 11 必需 的 ) 
password (varchar 2C 
QQ (varchar 20) 
question (varchar SC 
sex (warchar 10 必需 
tel (varchar 50) 
truenane (varchar SC 


Ea 


二 丰 呈 起 瑟 中 外 由 瑟 引 岂 


usernane (varchar 2( 立 


< | 多 
图 4-13 绑 定 的 数据 库 


2 42 用户 登录 功能 
本 小 节 主要 介绍 用 户 登录 功能 的 制作 ， 用 户 管理 系统 的 第 一 个 功能 就 是 要 提供 一 
会 员 进 行 登录 的 窗口 。 
和 421) 设计 从 录 页 面 
在 用 户 访问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登录 页 面 来 实现 
的 。 所 以 登录 页 面 中 必须 有 要 求 用 户 输入 用 户 名 和 密码 的 文本 框 ， 以 及 输入 完成 后 进行 登 
录 的 “登录 ”按钮 和 输入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ”按钮 。 
详细 的 制作 步 又 如 下 : 


加 首先 来 看 一 下 用 户 登 录 的 首页 设计 ， 如 图 4-14 所 示 。 


- 138 - 


ET 


0S 71 “IIISlx 
€|© |8) ||® np//127.00.Umember/inder php BEY 


图 4-14 ”用户 登 录 系统 首页 


index.php 页 面 是 用 户 登 录 系 统 的 首页 ， 打 开 前 面 创建 的 index.php 页 面 ， 输 入 网 页 
标题 “PHP 用 户 管理 系统 ”， 然 后 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 将 网 页 标题 保存 。 
执行 菜单 栏 “ 修 改 ” 一 “页 面 属 性 ”命令 ， 然 后 在 “背景 颜色 ”文本 框 中 输入 项 
色 值 为 #CCCCCC， 在 “上 边 距 ”文本 框 中 输入 0px， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 
个 表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-15 所 示 。 


图 4-15 “页 面 属性 ”对 话 框 

设置 完成 后 单 击 “ 确 定 ” 按 钮 ， 进 入 “文档 ”窗口 ， 执 行 菜单 栏 “ 插 入 ”一 “ 表 
格 ”命令 ， 打 开 “ 表 格 ”对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 为 3， 在 
“ 列 数 ”文本 框 中 输入 需要 插入 表格 的 列 数 为 3， 在 “表格 宽度 ”文本 框 中 输入 775 像 素 ， 
设置 “边框 粗细 ”、“ 单 元 格 边 距 ”和 “间距 ”都 为 0， 如 图 4-16 所 示 。 
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行 数 :3 列 3 
志 格 帘 度 175 入 素 = 


边框 相 细 : 0 。 鲁 素 


单元 格 边 距 : 0 ”图 


图 4-16 设置 “表格 ”属性 
单 击 “确定 ” 按 钮 ， 这 样 就 在 “文档 ”窗口 中 插入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 
放置 在 第 1 行 表格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 回 |， 
将 第 1 行 表格 合并 ， 再 执行 菜单 栏 “ 插 入 ”一 “图 像 ”命令 ， 打 开 “ 选 择 图 像 源 文件 ”对 
话 框 ， 在 站 以 mages 交 件 类 中流 掺 困 玉 0 gif， 如 图 4-17 所 示 。 


到 es 9 
esl = ER 

HH EA 

9 .9 

ag# Cr 07 

mr Eee 

文件 名 (Ni 01.gif 图 条文 件 fgit jpg7jpeg pv 
ee) Ce 


图 4-17 “选择 图 像 源 文 件 ” 对 话 框 
国 单 击 “ 确 定 ”按钮 ， 即 可 在 表格 中 插入 此 图 片 。 将 鼠标 指针 放置 在 第 3 行 表格 中 ， 
在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ” 按 馈 国 ， 将 第 3 行 所 有 单元 格 合并 ， 
再 执行 菜单 栏 “ 插 入 ”一 “图 像 ”命令 ， 打 开 “选择 文件 ”对 话 框 ， 在 站 点 images 文 件 央 
中 选择 图 片 05.gif， 插 入 一 个 图 片 ， 效 果 如 图 4-18 所 示 。 
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第 4 章 全 程 实 例 


图 4-18 插入 图 片 效果 图 


插入 图 片 后 ， 选 择 插入 的 整个 表格 ， 在 “属性 ”面板 的 “对 齐 ” 下 拉 列 表 框 中 ， 
选择 “居中 对 齐 ” 选 项 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-19 所 示 。 


图 4-19 设置 “居中 对 齐 ” 

把 光标 移 至 创建 表格 第 2 行 第 1 列 中 ， 在 “属性 ”面板 中 设置 高 度 为 456 像 素 、 宽 度 
为 179 像 素 ,设置 高 度 和 宽度 根据 背景 图 像 而 定 ， 从 “背景 ”中 选择 该 站 点 中 images 文 件 夹 
中 的 02.gif 文 件 ， 得 到 效果 如 图 4-20 所 示 。 

画 


a ET 


会 员 登 录 


4-20 插入 图 片 的 效果 图 


在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插入 同 站 点 images 文 件 夹 中 的 图 片 03.gif 和 和 
04.gif， 完 成 网 页 的 结构 搭建 ， 如 图 4-21 所 示 。 


= 


ea 网 站 开发 全 程 实例 (第 2 版》 
Giga rs 


动 cvamppihtdocsmembeindexpho” 
会 员 登 录 
产品 况 明 : 三星 管 能手 机 ,100 万 从 ,到 3、 四 4 
和 芋 相 技术 . 季 写 功 时, 外 观 美 等 特点 。 
说 从 :20 
会 ft: ¥2le0 
产品 分 类 
ER 中 其 是 国产 中 从 手机 中 有 新 贞 的 一 部 特 针 机 。 
局部 hn oi 硬 作 系统 ， 配 有 大 所 的 VERTY 全 刍 
ge 熏 ， 内 于 :20 万 全 素 的 所 才 头 ， 支持 联 下 2C 隔 络 
图 # 辣 程 城村 价 ; 兰 2450 
名 敌手 机 会 RT: 兰 2180 
购物 流程 
1. 连 购 产品 
之 确定 订 网 RN: Ae 
了 网 上 人 区 porrarr 全 健生 的 于 机 交加 一 般 生计 的 母 
4 填写 信息 1 庆 者 价 : 半 10558 
5 入 产品 会 员 价 : $030 
I i 


图 4-21 完成 的 网 页 背景 效果 图 
单 击 第 2 行 第 1 列 单元 格 ,然后 再 单 击 “ 文 档 ” 窗口 上 的 国 了 加 加 禄 钮 ， 在 <td> 和 </td> 
之 间 加 入 valign="top" (表格 文字 和 图 片 的 相对 摆 放 位 置 ， 可 选 值 为 top,，middle，bottom ) 
的 命令 ， 表 示 让 和 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部 ， 设 置 如 图 4-22 所 示 。 


Dw xelf wk EsV) 得 NI ARM ER(O 3(O walS CW) melt -| Ol=lel*] 


i 


| 而 [ 折 7 六 叶 3 本 。 三。 全 四 。T 打 户 管理 不 级 


区 二 性 村 入 条 来 局 


回民 
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Fo 
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图 4-22 设置 单元 格 的 对 齐 方式 为 最 上 


(VB 


文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 它 们 提供 各 种 文档 “窗口 视图 ” (如 “设计 ”、“ 拆 分 ” 
和 “代码 ”视图 ) ， 各 种 查看 选项 和 一 些 常用 操作 (如 在 浏览 器 中 预览 )。 
单 击 “ 文 档 ” 窗 口上 的 [设计 | 按钮 返回 文档 窗口 的 “设计 ”窗口 模式 ， 在 刚 创 
建 的 表格 的 单元 格 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ”一 “表单 ”命令 (如 图 4-23 所 示 ) ， 
插入 一 个 表单 。 
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图 4-23 执行 “表单 ”命令 

将 鼠标 指针 放置 在 该 表单 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 
对 话 框 ， 在 “ 行 数 ” 文 本 框 中 输入 5， 在 “ 列 数 ” 文 本 框 中 输入 2。 在 “表格 宽度 ”文本 框 
中 输入 179 像 素 ， 在 该 表单 中 插入 5 行 2 列 的 表格 。 单 击 并 拖 动 饼 标 分 别 选 择 第 1 行 、 第 2 行 
和 第 5 行 表格 ， 并 分 别 在 “属性 ”面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 回 ， 
将 这 几 行 表格 进行 合并 。 然 后 在 表格 的 第 1 行 输入 “会 员 登 录 ” 四 个 字 ， 在 第 2 行 第 1 列 中 
输入 文字 说 明 “用 户 名 ”， 在 第 2 行 第 2 列 中 执行 菜单 栏 “ 插 入 ”一 “表单 ”一 “文本 域 ” 
命令 ， 插 入 一 个 单行 文本 域 表 单 对 象 ， 并 定义 文本 域名 为 “username”， “文本 域 ”属性 
设置 如 图 4-24 所 示 。 

慰 性 


画 文本 城 字符 宽度 mW 1)2 | 类 型 @ 音 行 6) 。 〇 多 行 ) 。 〇 和 区 吗 @) 类) 无 本 
一 [ernw。 | 最 多 字符 数 | | 初 如 入 CI) | 1] 
口 药 用 O) 
口内 娘 四 
图 4-24 “文本 域 ”的 设置 
设置 文本 域 的 属性 说 明 如 下 : 


@ 在 “文本 域 ”文本 框 中 为 文本 域 指 定 一 个 名 称 ， 每 个 文本 域 都 必须 有 一 个 惟一 名 
称 。 表单 对 象 名 称 不 能 包含 空格 或 特殊 字符 。 可 以 使 用 字母 数字 字符 和 下 划 线 (一 ) 
的 任意 组 合 。 请 注意 ， 为 文本 域 指定 的 标签 是 存储 该 域 的 值 ( 输入 的 数据 ) 的 变 
量 名 ， 这 是 发 送 给 服务 器 进行 处 理 的 值 。 

@ “字符 宽度 ”设置 域 中 最 多 可 显示 的 字符 数 。“ 最 多 字符 数 ” 指 定 在 域 中 最 多 可 
输入 的 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽 度 ” 可 以 小 于 “最 
多 字符 数 ”， 但 大 于 字符 宽度 的 输入 则 不 被 显示 。 

@ “类 型 ”用 于 指定 文本 域 是 “单行 ”、“ 多 行 ”， 还 是 “密码 ” 域 。 单 行文 本 域 
只 能 显示 一 行文 字 ， 多 行 则 可 以 输入 多 行文 字 ， 达 到 字符 宽度 后 换行 ， 密 码 文本 
域 则 用 于 输入 密码 。 
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pip 人 


@ “初始 值 ” 指 定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 
值 ， 可 以 指示 用 户 在 域 中 输入 信息 。 
@ (5) “类 ”可 以 将 CSS 规 则 应 用 于 对 象 。 


在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “密码 ”， 在 第 3 行 表格 的 第 2 列 中 执行 菜单 栏 
“插入 ”一 “表单 ”~ “文本 域 ”命令 ， 插 入 密码 文本 域 表单 对 象 ， 定 义 “ 文 本 域 ” 名 为 
password。 “文本 域 ” 属 性 设置 及 此 时 的 效果 如 图 4-25 所 示 。 


属性 


串 文本 域 FN 1 | 闫 型 〇 单行 5) OSFm OHE) sr) 无 ~| 
[password | 最 多 字符 数 | 初 巡 秆 0) | ] 8 

口 药 用 加 ) 

口 R 污 虽 


图 4-25 密码 “文本 域 ” 的 设置 

选择 第 4 行 单元 格 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ”一 “按钮 ”命令 两 次 ， 插 入 两 
个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 
一 个 为 “ 重 设 表单 ”选项 ，“ 属 性 ”的 设置 如 图 4-26 所 示 。 


属性 

| 开间 各 部 值 W) 莘 录 动作 @ 提交 表单 6) 〇 无 吕 类 加 [无 加 | 
Bumit | ORaR 四 

属性 

| 开交 值 W) 萤 村 动作 〇 提交 表单 S) 〇 无 0n 关口 | 无 司 
[umitz | 加 重 设 表单 四 ) 


图 4-26 设置 按钮 名 称 


在 第 5 行 输入 “注册 新 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 register.php 的 链 
接 对 象 ， 以 方便 用 户 注 册 ， 如 图 4-27 所 示 。 


属性 


《7m | 格式 0 | 无 加 机 [无 vBZ 丘 汪 要 术科) | 
本 cs nD) 无 链接 0) reester php YGD #0 = 
| PW wl] TAF NREC | 
口 北 三 直 加 | 默认 Yj 高 09| 22] 标 归 中) 门 ] 
图 4-27 建立 链接 


圈 如 果 已 经 注册 的 用 户 忘记 了 密码 ， 还 希望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 查询 页 面 lostpassword.php 的 
链接 对 象 ， 方 便 用 户 取 回 密码 ， 如 图 4-28 所 示 。 


属性 


2m | 格式 9) 无 
Bs nm 


| E gl 
国 单元 格 水平) 驶 人 ~ | 实 o | | 不 执行 0) 门 。 凋 景 绍 包 (6) 三 | E 
口 让 ”要 下 中 内 ~ 高 00| 2 标题 @) 口 


图 4-28 ”密码 查询 设置 
辆 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 使 用 户 可 以 通过 该 网 页 中 表单 
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的 提交 实现 登录 功能 。 打 开 “ 服 务 器 行为 ”面板 ， 单 击 该 面板 上 国 按 钮 ， 执 行 菜单 栏 “ 用 
户 身 份 验证 ”一 “登录 用 户 ” 命 令 (如 图 4-29 所 示 ) ， 向 该 网 页 添加 “登录 用 户 ” 的 服务 
器 行为 。 


Dw x wan 二 可 SND Wm) IO si0 Was) OW a 
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了 人 | i RT | Sat 团 。 全 i APEEFS 


> 
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Ne am 
和 -a 
ERF 


图 4-29 添加 “登录 用 户 ”的 服务 器 行为 
国 打开 “登录 用 户 ” 对 话 框 ， 各 项 参数 设置 如 图 4-30 所 示 。 


2 
5 CD 

| = Cw 

如 果 登 录 成 功 ， 转 到 : welcome php 济 

固 转 到 前 一 个 URL (如 果 它 存在 ) 

| 如果 登 录 失 败 ， 转 到 ; leginfsil php 测 

基于 以 下 项 限制 访问 : 加 用 户 名 和 密码 

用 户 名 、 密码 和 访问 级 别 
| 获取 级 别 自 : 世 
ES 


图 4-30 一 和 录用 户 - 对 话 框 
该 对 话 框 中 各 项 设置 的 作用 如 下 


@ 从 “从 表单 获取 输入 ”下 拉 列 表 框 中 选择 该 服务 器 行为 使 用 网 页 中 的 form1 对 象 ， 
设 定 该 用 户 登 录 服 务 器 行为 的 用 户 数 据 来 源 为 表单 对 象 中 访问 者 填写 的 内 容 。 

@ 从 “用 户 名 字段 ”下 拉 列 表 框 中 选择 文本 域 username 对 象 ， 设 定 该 用 户 登 录 服 务 
器 行为 的 用 户 名 ， 数 据 来 源 为 表单 的 username 文 本 域 中 访问 者 输入 的 内 容 。 

@ 从 “密码 字段 ”下 拉 列 表 框 中 选择 文本 域 password 对 象 ， 设 定 该 用 户 登录 服务 器 行 
为 的 用 户 名 ， 数 据 来 源 为 表单 的 password 文 本 域 中 访问 者 输入 的 内 容 。 
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3 人 ee 加 


@ 从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登 录 服务 器 行为 使 用 的 数据 源 连接 
对 象 为 nymember。 
从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登 录 服 务 器 行为 使 用 到 的 数据 库 表 对 象 为 
member。 
从 “用 户 名 列 ” 下 拉 列 表 框 中 ， 选 择 表 member 存 储 用 户 名 的 字段 为 username。 
从 “密码 列 ” 下 拉 列 表 框 中 ， 选 择 表 member 存 储 用 户 密 码 的 字段 为 password。 
在 “如 果 登 录 成 功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 转向 welcome.php 页 面 。 
在 “如 果 登 录 失 败 ， 转 到 ”文本 框 中 输入 登录 失败 后 转向 loginfail.php 页 面 。 
选中 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 将 根 
据 用 户 的 用 户 名 、 密 码 共 同 决定 其 访问 网 页 的 权限 。 

设置 完成 后 ， 单 击 “确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 就 增加 了 一 个 “登录 用 户 ” 行 为 ， 如 图 4-31 所 示 。 


| 1R% 3 行为 
十 一 文档 型 : pm 
瑟 录 用 户 


图 4-31 “服务 器 行为 ”面板 
团 表单 对 象 对 应 的 “属性 ”面板 的 动作 属性 值 为 <?php echo $loginFormAction; ?>， 
如 图 4-32 所 示 。 它 的 作用 就 是 实现 用 户 登 录 功 能 ， 这 是 一 个 Dreamweaver 自动 生成 的 动作 
代码 。 


副 表单 ID 动作 [Gephp echo $loginFormhetion; ?》 | 回 目标 ) | 加 | 类 GO| 无 
~ 
| 


[Eornl | 方法 [Posr ~ 编码 类 型 


图 4-32 表单 对 应 的 “属性 ”面板 
执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 
首页 制作 。 


< 422 登录 成 功 和 失败 

当 用 户 输入 的 登录 信息 不 正确 时 ， 就 会 转 到 loginfail.php 页 面 ， 显 示 登 录 失 败 的 信息 。 
如 果 用 户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome.php 页 面 。 

(1) 执行 菜单 栏 “ 文 件 ” 一 “新 建 ” 命 令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 loginfail.php 
的 网 页 并 保存 。 

(2) 登录 失败 页 面 设计 如 图 4-33 所 示 。 在 “文档 ”窗口 中 选中 “这 里 ”文本 ,在 其 对 
应 的 “属性 ”面板 上 的 “链接 ”文本 框 中 输入 index.php， 将 其 设置 为 指向 index.php 页 面 的 
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链接 。 


-BT 污 二 三 三 中 
-0m hm 
人 Er 外 [js 


3 本 
图 4-33 ”登录 失败 页 面 loginfail.php 
(3) 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 完 成 loginfail.php 页 面 的 创建 。 
制作 welcome.php 页 面 ， 详 细 制 作 的 步骤 如 下 : 
执行 菜单 栏 “文件 ” 一“ 新建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 welcome.php 
的 网 页 并 保存 。 
加 用 类 似 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-34 所 示 。 


加 执行 菜单 栏 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 国 按 钮 ， 
os “阶段 变量 ”选项 ， 为 网 页 中 定义 一 个 阶段 变量 ， 如 图 4-35 所 示 。 


图 4-34 欢迎 界面 的 效果 图 图 4-35 添加 阶段 变量 
人 ”全 3 仁 )” 
阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 象 ， 用 户 信息 得 以 存储 ， 并 使 该 信息 在 用 户 访问 的 持续 
时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变量 还 可 以 提供 一 种 超时 形式 的 安全 对 象 ， A 
在 用 户 账 户 长 时 间 不 活动 的 情况 下 ， 终 止 该 用 户 的 会 话 。 如 果 用 户 忘 记 从 Web 站 点 注销 ， 这 
; 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资源 。 


园 打开 “阶段 变量 ”对 话 框 。 在 “名 称 ” 文 本 框 中 输入 “阶段 变量 ”的 名 称 
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人 AA 人 
Cs ,i 


MM _ username， 如 图 4-36 所 示 。 

设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 在 “文档 ”窗口 中 通过 拖 动 据 标 
选择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM_username 变 量 ， 再 单 击 “ 绑 定 ” 
面板 底部 的 “插入 ”按钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 插 入 完毕 ， 可 以 看 
到 “XXXXXX” 文 本 被 {Session.MM_username} 占 位 符 代 替 ， 如 图 4-37 所 示 。 这 样 ， 就 完 
成 了 这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 


名 称 : I0Lusername| 


图 4-36 “阶段 变量 ”对 话 框 图 4-37 插入 后 的 效果 


设计 阶段 变量 的 目的 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 直接 显示 用 户 的 名 字 ， 使 网 页 更 有 
亲切 感 。 


国 在 “文档 ”窗口 中 拖 动 鼠 标 选 中 “注销 你 的 用 户 ” 文 本 。 执 行 菜单 栏 “ 窗 口 ”~ 
“服务 器 行为 ”一 “用 户 身份 验证 ”一 “注销 用 户 ” 命 令 ， 为 所 选中 的 文本 添加 一 个 “ 注 
销 用 户 ” 的 服务 器 行为 ， 如 图 4-38 所 示 。 
DW ZH) Wl EBV A HEM) Rl) oO Al) ac ol -| ot-lel x 


信阳 | 白 分 丙 计 | HR 四。 埠 ， 标题， 光 H 而 


图 4-38 “注销 用 户 ” 命令 
打开 “注销 用 户 ” 对 话 框 。 在 该 对 话 框 中 进行 如 图 4-39 所 示 的 设置 。 
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En Se li 
在 以 下 情况 下 注销 - 回 单 击 链接 “ 主 稍 从 的 用 户 ” = [| 
取消 
在 完成 后 , 转 到 : logout Fhp ET (Bl 


图 4-39 ”设置 完成 后 的 “注销 用 户 ” 对 话 框 
国 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 链 接 文 本 对 
应 的 “属性 ”面板 中 的 “链接 ”属性 值 为 <?php echo $logoutAction ?>， 它 是 Dreamweaver 
自动 生成 的 动作 对 象 。 
国 logoutphp 的 页 面 设计 比较 简单 ， 不 作 详 细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index.php 就 可 以 了 ， 效 果 如 图 4-40 所 示 。 
二 cyampp\htdocsymemberVJogout php HTMU -Ox 
人 
新 录 清单 这 里 。 


图 4-40 注销 用 户 页 面 设计 效果 图 
执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 编 辑 工作 完 
成 后 ， 就 可 以 测试 该 用 户 登录 系统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 注册 资料 ”链接 到 
userupdate.php 页 面 ， 此 页 面 将 在 后 面 的 小 节 中 进行 介绍 。 


-463 ) 测 试 登录 功能 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 嚣 使用。 下面 就 对 登录 系统 进行 
测试 ， 测 试 的 步骤 如 下 : 

加 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/member， 打 开 index.php 页 面 ， 如 
图 4-41 所 示 。 


EE 二 
全 全 | 六 | 加 


127001 


图 4-41 打开 的 网 站 首页 
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0 


按钮 。 
国 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 , 或 者 根本 就 没有 输入 , 则 浏览 器 就 会 转 


到 登录 失败 页 面 loginfail.php， 显 示 登 录 错 误 信 息 ， 如 图 4-42 所 示 。 


在 “用 户 名 ”和 “密码 ”文本 框 中 输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “登录 ” 


EE 
| 全 有 太 | 加 127001 BEv 
CY ea x + 


SR 


图 4-42 登录 失败 页 面 loginfail.php 效果 
加 如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 这 里 输入 的 是 前 面 数据 
人 登录 成 功 后 的 页 面 如 图 4-43 所 示 ， ea 


2 i ~ 
用 户 登 录 用 户 注册 “| ”资料 修改 
Se wee mr 
nna He 
ee 二 :ga 
3 
es 
Bake | 
rar | 
Ee 
风物 六 但 


图 4-43 ”登录 成 功 页 面 welcome.php 效 果 
如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链接 即 可 ， 注 销 用 户 后 ， 浏 览 
器 就 会 转 到 页 面 logout.php， 然 后 单 击 “这 里 ” 回 到 首页 ， 如 图 4-44 所 示 。 至 此 ， 登 录 功 能 


就 测试 完成 了 。 


- 150 - 


ET 


E300 7 
专 九 | 会 | 契 | 国 hitp://127.0.0.Umembe 


图 4-44 注销 用 户 页 面 设计 
志 4.3 ”用 户 注册 功能 


用 户 登 录 系 统 是 为 数据 库 中 己 有 的 老 用 户 登录 用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 
用 户 注册 用 的 页 面 ， 对 于 新 用 户 来 说 , 通过 单 击 index.php 页 面 上 的 “注册 新 用 户 ” 超 链接 ， 
进入 到 名 为 register.php 的 页 面 ， 在 该 页 面 可 以 实现 新 用 户 注册 功能 。 


LT ) 用 户 注册 页 面 


register.php 页 面 主要 实现 用 户 注 册 的 功能 ， 用 户 注 册 的 操作 就 是 向 数据 库 的 member 表 
中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-45 所 示 。 
霄 cvampo\ntdocswnembervegister php" 
首页 


| 产 员 轨 类 
华 上 电脑 
数码 |8 机 
图 得 

3 各 随手 机 

“| 购物 流程 

i 
和 确定 订购 
到 网 上 付款 
闷 杆 写 信 息 


sa i 
1 3 


1 ' 
WS WH We WW tl [TEIES 


图 4-45 用户 注册 页 面 样式 
加 执行 菜单 栏 “ 文 件 ” 一 “新建” 命令， 在 网 站 根 目 录 下 新 建 一 个 名 为 register.php 
的 网 页 并 保存 。 
在 Dreamweaver 中 ,使 用 制作 静态 网 页 的 工具 完成 如 图 4-46 所 示 的 静态 部 分 。 这 里 
要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ”并 命名 为 authority， 设 置 默认 值 为 0， 即 所 有 
的 用 户 注册 的 时 候 默 认 是 一 般 访问 用 户 。 


请 用 户 让 真正 写 注册 信 筷 


图 4-46 register.php 页 面 静态 设计 
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在 为 表单 中 的 六 本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 member 表 中 ， 可 以 将 表单 
对 象 中 的 文本 域名 设置 的 与 数据 库 中 的 相应 字段 名 相同 ， 这 样 做 的 目的 是 当 该 表单 中 的 内 容 添 
加 到 member 表 中 时 会 自动 配对 ， 文 本 “重复 密码 ”对 应 的 文本 框 命名 为 passwordl 。 隐 藏 域 是 
用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 说 ， 隐 藏 域 是 看 不 见 的 。 当 表单 被 提 
交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 到 服务 器 上 。 


还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 否 满足 
数据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 填写 的 注册 资料 提交 到 服务 器 之 前 , 就 会 对 用 
户 填写 的 资料 进行 验证 。 如 果 有 不 符合 要 求 的 信息 ， 可 以 向 访问 者 显示 错误 的 原因 ， 并 让 
访问 者 重新 输入 。 

加 执行 菜单 栏 “ 窗 口 ”一 “行为 ”命令 ， 则 会 打开 “行为 ”面板 。 单 击 “ 行 为 ” 

板 中 的 国 接 和 钮 ， 从 打开 的 行为 列表 中 选择 “检查 表单 ”， St “检查 表单 ”对 话 框 ， Me 
4-47 所 示 。 


) 电子 邮件 地 址 数字 从 到 


图 4-47 设置 “检查 表单 ”对 话 杠 
惟 起 [总 时 


本 例 中 , 我 们 设置 username 文 本 域 、password 文 本 域 、password1 文 本 域 、answer 文 本 域 、truename 
文本 域 、address 文 本 域 为 “ 值 : 必需 的 ”、“ 可 接受 : 任何 东西 ”， 即 这 几 个 文本 域 必 须 填写 ， 
内 容 不 限 ， 但 不 能 为 空 ，tel 文 本 域 和 qq 文本 域 设置 的 验证 条 件 为 “ 值 : 必需 的 ”、“ 可 接受 ， 

数字 ”, 表示 这 2 个 文本 域 必须 填写 数字 , 不 能 为 空 ; e-mail 文 本 域 的 验证 条 件 为 “ 值 : 必需 的 ”、 
“可 接受 : 电子 邮件 地 址 ”， 表 示 该 文本 域 必须 填写 电子 邮件 地 址 ， 且 不 能 为 空 。 


设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 完 成 对 检查 表单 的 设置 。 
四 在 “文档 ”窗口 中 单 击 工具 栏 上 的 国史 四 按钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验证 
表单 动作 的 源 代码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 : 
<script type="text/javascript"> 
// 宣 告 脚本 语言 为 JavaScript 
function MM validateForm() { //v4.0 
if (document.getElementById){ 


Var 
i,pqrnm,test,num,min,max,errors='',args=MM validateForm.arguments; 
for (i=0; i<(args.length-2); i+=3) 下 test=args [i+2]; 


val=document .getElementById (args [i]); 
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ea 
@ sr ® 
@ ® 
if (val) { nm=val.name; if ((val=val.value)!="") { 
if (test.indexOf('isEmail')!=-1) { p=val.indexOf ('@'); 
if (p<1 11 p==(val.length-1)) errors+='- '+nm+' 需 要 输入 邮箱 地 
EN 
// 如 果 提 交 的 邮箱 地 址 表单 中 不 是 邮件 格式 则 显示 为 “需要 输入 邮箱 地 址 ” 
} else if (test!='R') { num = parseFloat (val); 
if (isNaN(val)) errors+='- '+nm+' 需 要 输入 数字 .\n'; 
// 如 果 提 交 的 电话 表单 中 不 是 数字 则 显示 为 “需要 输入 数字 ” 
if (test.indexof('inRange') != -1) { p=test.indexOf(':'); 
min=test.substring(8,p); max=test.substring(P+1) 7 
if (num<min || max<num) errors+='- '+nm+' 需 要 输入 数字 '+min+' 
and "tmaxt" NE 
// 如 果 提 交 的 QQ 表单 中 不 是 数字 则 显示 为 “需要 输入 数字 
} } } else if (test.charAt(0) == 'R') errors += '- '+nm+' is 需 
要 输入 .\n'; } 
// 如 果 提交 的 地 址 表单 为 空 则 显示 为 “需要 输入 “ 
} if (errors) alert(' 注 册 时 出 现 如 下 错误 :\n'+errors); 
// 如 果 出 错 是 将 显示 “注册 时 出 现 如 下 错误 : 
document .MM_returnValue = (errors == ''); 
下 
</script> 


编辑 代码 完成 后 ， 单 击 工具 栏 上 的 攻 潭 按钮， 返回 到 “文档 ”窗口 。 

此 时 ， 可 以 测试 一 下 执行 的 效果 ， 当 两 次 输入 的 密码 不 一 致 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 
则 会 打开 一 个 提示 信息 框 ， 如 图 4-48 中 的 警告 信息 。 

在 该 网 页 中 添加 一 个 “插入 ”的 服务 器 行为 。 执 行 菜单 栏 “窗口 ”一 “服务 器 行 
为 ” 命令 , 打开 “服务 器 行为 ” 面板 . 单 击 该 面板 上 [到 该 钮 , 在 弹出 的 下 拉 菜 单 中 选择 “ 插 
入 记录 ”选项 ， 如 图 4-49 所 示 ， 则 会 打开 “插入 记录 ”对 话 框 。 


[7 古国 OleLx] 


cher > 
CII 7。 克 。 是 RE 二 


首 页 用 户 登录 


用 户 注册 


RE 


全。 注册 时 出 现 如 下 描 误 : 
A ermameis sR 和 
| - password is 需要 输入 、 
| - password1 is 需要 柱 入 . 
- truename is 需要 纺 入 . 


ER ER 
ET 
[ET 


- address is 寺 要 输入. 
- answer is 需要 蛤 入 . 


| 会 四 医 a DEEPTrZ 
3 


et Te 
各 FER 
让 有 mlaw 。 雪 m| 4 二 


图 4-48 提示 信息 框 图 4-49 执行 “插入 记录 ”操作 


加 在 对 话 框 中 进行 设置 ， 并 将 网 页 中 的 表单 对 象 和 数据 库 中 表 member 中 的 字段 一 一 
对 应 起 来 ， 设 置 完成 后 该 对 话 框 如 图 4-50 所 示 。 
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AR 


出 


图 4-50 “插入 记录 ”对 话 框 
国 设置 完成 后 ， 单 击 “ 确 定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 时 的 
设计 样式 如 图 4-51 所 示 。 


图 4-51 插入 记录 后 的 效果 图 
用 户 名 是 用 户 登 录 的 身份 标志 ， 用 户 名 是 不 能 够 重复 的 ， 所 以 在 添加 记录 之 前 ， 
一 定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 存在 , 如果 存 在 , 则 不 能 进行 注册 。 在 Dreamweaver 
中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “服务 器 行为 ”面板 上 国 按钮 ， 在 弹出 的 
菜单 中 ， 执 行 “ 用 户 身 份 验证 ”一 “检查 新 用 户 名 ”命令 ， 如 图 4-52 所 示 。 


Dw zxpm war eB AN sim ol seo el ECW et 部 国 0 l=-1eL x 只 
op 
上 上 


图 4-52 “检查 新 用 户 名 ”命令 
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此 时 ， 会 打开 一 个 “检查 新 用 户 名 ”对 话 框 ， 在 “用 户 名 字段 ”下 拉 列 表 框 中 选择 
username 字 段 ， 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 输入 regfail.php。 表 示 如 果 用 户 名 已 
经 存在 ， 则 转 到 regfail.php 页 面 ， 显 示 注 册 失 败 信息 ， 该 网 页 将 在 后 面 编 辑 。 设 置 完 成 后 
的 对 话 框 显示 如 图 4-53 所 示 。 


We 
. CE 
如果 已 存在 ， 风 到 -reefail php GE Cm 
Cm] 


图 4-53 “检查 新 用 户 名 ”对 话 框 

辆 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 关 闭 该 对 话 框 ,返回 到 “文档 ” 
窗口 。 在 “服务 器 行为 ”面板 中 增加 了 一 个 “检查 新 用 户 名 ”行为 ， 再 执行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 本 页 的 制作 。 
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为 了 方便 用 户 登 录 ， 应 该 在 regok.php 页 面 中 设置 一 个 转 到 index.php 页 面 的 文字 链接 ， 
以 方便 用 户 进行 登录 。 同 时 ， 为 了 方便 访问 者 重新 进行 注册 ， 则 应 该 在 regfail.php 页 面 设 
置 一 个 转 到 register.php 页 面 的 文字 链接 ， 以 方便 用 户 进行 重新 登录 。 本 节制 作 显示 注册 成 
功 和 失败 的 页 面 信息 。 


加 执行 菜单 栏 “ 文 件 ” 一“ 新建” 命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 regok.php 的 
网 页 并 保存 。 

regok.php 页 面 如 图 4-54 所 示 。 制 作 比 较 简 单 ， 其 中 将 文本 “这 里 ”设置 为 指向 
index.php 页 面 的 链接 。 


图 4-54 注册 成 功 regok.php 页 面 

如 果 用 户 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 向 用 户 显示 注册 失败 

的 信息 。 这 里 再 新 建 一 个 regfail.php 页 面 , 该 页 面 的 设计 如 图 4-55 所 示 。 其 中 将 文本 “这 里 ” 
设置 为 指向 register.php 页 面 的 链接 。 
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SS 1 
sa 网 站 开发 全 程 实例 (第 2 版 ) 


DW ssn man asm EM Sas En S50 ers enw we eR 
sa = E 
ER 3 


A 3 一 S| 


a 本 
童 页 用 户 登录 用 户 注册 责 料 由 改 害 码 查询 


图 4-55 注册 失败 regfail.php 页 面 


<- 433 ) 注 册 功能 的 测试 


设计 完成 后 ， 就 可 以 测试 该 用 户 注册 功能 的 执行 情况 了 。 


加 打开 下 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/register.php ， 


register.php 文 件 ， 如 图 4-56 所 示 。 


PT 


ls 


i 
Rs 


图 4-56 打开 的 测试 页 面 


贺 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username、password 等 必 填 
字段 ， 或 填写 非法 的 E-mail 地 址 ， 或 在 确认 密码 时 两 次 输入 的 密码 不 一 致 ， 以 测试 网 页 中 
验证 表单 动作 的 执行 情况 。 如 果 填 写 的 信息 不 正确 ， 则 浏览 器 应 该 打开 提示 信息 框 ， 向 访 
问 者 显示 错误 原因 ， 如 图 4-57 所 示 是 一 个 提示 信息 框 示例 。 
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打开 


E71 
4 全 | 会 太 | 回 127001 


图 4-57 出 错 提示 


辐 在 该 注册 页 面 中 注册 一 个 已 经 存在 的 用 户 名 ， 如 果 输 入 design， 用 来 测试 新 用 户 
服务 器 行为 的 执行 情况 。 然 后 单 击 “ 确 定 ” 按 钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 器 会 自 
动 转 到 regfail.php 页 面 ( 如 图 4-58 所 示 ) ， 告 诉 访问 者 该 用 户 名 已 经 存在 。 此 时 ,访问 者 可 
以 单 击 “ 这 里 ”链接 文本 ， 返 回 register.php 页 面 ， 以 便 重 新 进行 注册 。 


后 360 安 全 让 器 7.1 


所 | 二 || 全 || 太 J 外 127.0.0.1 BEY 


[SS ee = + 
用 户 登录 用 户 注册 资料 修改 


注册 失 吃 : 
3 不 新 刘 电 ， 你 三 几 的 用 户 各 已 经 祯 祥 册 
表单 志 证 里 重 六 主 轨 ! 


图 4-58 注册 失败 页 面 显 示 
国 在 该 注册 页 面 中 填写 正确 的 注册 信 ， 单 击 “ 确 定 ”按钮 。 由 于 这 些 注册 资料 完全 
正确 ， 而 且 这 个 用 户 名 没有 重复 。 浏 览 器 会 转 到 regok.php 页 面 ， 向 访问 者 显示 注册 成 功 的 
信息 ， 如 图 4-59 所 示 。 此 时 ， 访 问 者 可 以 单 击 “ 这 里 ”链接 文本 ， 转 到 index.php 页 面 ， 以 
便 进 行 登录 。 
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S Wn 发 全 程 实 


4 
用 户 注册 资料 修改 


图 4-59 注册 成 功 页 面 
在 MySQL 中 打开 用 户 数 据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 
以 看 到 ， 在 该 表 的 最 后 ， 创 建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚才 在 网 页 register.php 中 提 
交 的 注册 用 户 的 信息 ， 如 图 4-60 所 示 。 


EE We 


全 站 太 | 回 127001 LEv 


Ia ETT re 
phpMyAdmin EL CE 
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全 引入 | 二 [el 
OD enermame password queston anewet reneme sex ad | 
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日 en i 
ma OM Zam I mpimmbe Mme tt 
Me 75 Fu Om Bs 
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图 4-60 表 member 中 添加 了 一 条 新 记录 


至 此 ， 基 本 完成 了 用 户 管理 系统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根 
据 制作 网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 部 分 
添加 星 号 〈*) ， 提 醒 注册 用 户 注意 。 


7 4.4 ”修改 用 户 资料 


修改 注册 用 户 资料 的 过 程 就 是 往 用 户 数据 表 中 更 新 记录 的 过 程 ,本 节 重 点 介绍 如 何在 用 户 
管理 系统 中 实现 用 户 资料 的 修改 功能 。 
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< 和 4.4.1 ) 修 改 资料 页 面 


该 页 面 主要 把 用 户 所 有 资料 都 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 具 
体 的 制作 步骤 如 下 : 


修改 资料 的 页 面 和 用 户 注册 页 面 的 结构 十 分 相似 ， 可 以 通过 对 registerphp 页 面 的 
修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 registerphp 页 面 ， 执 行 菜单 栏 “文件 ” 一“ 另 
存 为 ”命令 ， 将 该 文档 另存 为 userupdate.php， 并 在 第 一 行 加 入 如 下 代码 : 

<?PhP 


session start(); 
?> 


// 启动 session 环 境 


执行 菜单 栏 “ 窗 口 ”- “服务 器 行为 ”命令 ， 打 开 “服务 器 行为 ”面板 。 在 “ 服 
务 器 行为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文字 ， 该 页 面 修 改 完成 后 显示 如 
图 4-61 所 示 。 


[TIEEEETETTTTETCTTE 


| 
1 
Lb i 
4 


CE R= 


图 4-61 userupdate.php 静态 页 面 

执行 菜单 栏 “ 窗 口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 的 按钮 ， 
在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

在 该 对 话 框 中 进行 如 下 设置 : 
在 “名 称 ” 文 本 框 中 输入 upuser 作 为 该 “记录 集 ” 的 名 称 。 
从 “连接 ”下 拉 列 表 框 中 选择 “user 数 据 源 ”连接 对 象 为 mymember。 
从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member。 
在 “ 列 ” 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 
在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 username= 阶 段 变量 / MM_Username。 
完成 后 的 设置 如 图 4-62 所 示 。 


|} eeeee 
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图 4-62 定义 upuser“ 记 录 集 ” 


设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 完 成 记录 集 的 绑 定 。 
国 完成 记录 集 的 绑 定 后 将 upuser 记 录 集 中 的 字段 绑 定 到 页 面相 应 的 位 置 上 ， 注 意 插 
入 一 个 隐藏 域 为 id， 设 置 在 用 户 名 字段 的 后 面 ， 如 图 4-63 所 示 。 
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用 户 名 

沁 


{ 
ES i 
etn 1 
ee | 
i 
1 
1 


人 机 
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3 同上 人 区 
全 二 信息 


4 而 , 
BI Vo We 让 le wa [nm 目 目 量 柄 5557 


4-63 ” 绑 定 动态 内 容 后 的 userupdate.php 页 面 
对 于 网 页 中 的 单 选 按钮 组 sex 对 象 ， 绑 定 动态 数据 可 以 按照 如 下 方法 ， 单 击 “服务 
器 行为 ”面板 上 [区 污 钮 ， 在 弹出 的 下 拉 菜 单 中 ,执行 “动态 表单 元 素 ” 一 “动态 单 选 按钮 
命令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 。 从 “ 单 选 按钮 组 ”下 
拉 列 表 框 中 选择 form1 表 单 中 的 单 选 按钮 组 sex。 单 击 “ 选 取 值 等 于 ”文本 框 后 面 的 国 | 按钮， 
从 打开 的 “动态 数据 ”对 话 框 中 选择 记录 集 upuser 中 的 sex 字 段 ， 同 样 对 提问 的 问题 列表 进 
行动 态 绑 定 ， 如 图 4-64 所 示 。 


TREE 2 


单 先 按 包 组 | =o” 在 表单 “Ear” 3 亡 枉 


选取 值 等 于 -《?php $row_upuser[ sex”] ?> | 取消 
EE 


图 4-64 设置 “动态 单 选 按钮 组 ”对 话 框 
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第 4 章 全 程 实例 二 : 用 户 管理 系统 . El 
. Go 


国 单 击 “ 服 务 器 行为 ”面板 上 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ”选项 ， 
为 网 页 添加 更 新 记录 的 服务 器 行为 ， 如 图 4-65 所 示 。 


DW xen man sam EMD wm Ao) E30) WE OW em 又 - Ba Ol=lol x] 
EL - 


图 4-65 选择 “更 新 记录 ”选项 
打开 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 插入 记录 的 对 话 框 十 分 相似 ， 具 体 的 设置 
情况 如 图 4-66 所 示 ， 这 里 不 再 重复 。 


在 更 新 后 , 转 到 userupdateok. Php 


图 4-66 一 更 新 记录 ”对 话 杠 
设置 完成 后 ， 单 击 “ 确 定 ”按钮 ， 关 闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 再 执行 
菜单 栏 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 


[| 


; ”由 于 本 页 的 MM_Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 , 所 以 单独 测试 时 会 提示 出 错 
; 的 ， 要 先 登 录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资料 ” 超 链接 到 该 页 面 才 会 产生 效果 ， 
: 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 : 


< 入 432 更 新 成 功 页 面 


用 户 修改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok.php。 在 该 网 页 中 ， 应 该 向 用 户 显示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 
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国生 


Ce (第 2) 


其 提供 一 个 返回 到 userupdate.php 页 面 的 超 文 本 链接 : 如 果 用 户 不 需要 修改 ， 则 为 其 提供 一 
个 转 到 用 户 登 录 页 面 mdex.php 的 超 文 本 链接 。 有 具体 的 制作 步骤 如 下 : 


加 执行 菜单 栏 “文件 ” ~“ 新 建 "命令 , 在 网 站 根 目录 下 新 建 一 个 名 为 userupdateok.php 
的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 
<?php 
session start(); 


?> 
// 启动 session 环 境 


为 了 向 用 户 提供 更 加 友好 的 界面 ， 则 应 该 在 网 页 中 显示 用 户 修改 的 结果 ， 以 供用 
户 检查 修改 是 否 正确 。 我 们 首先 应 该 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插 入 到 网 页 中 
相应 的 位 置 ， 其 方法 跟 制 作 页 面 userupdate.php 中 的 方法 一 样 。 通 过 在 表格 中 添加 记录 集中 
的 动态 数据 对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 ， 这 里 不 作 详细 说 明 ， 请 参考 前 面 一 
小 节 ， 最 终结 果 如 图 4-67 所 示 。 


二 cyamppintdocs\member\userupdateok php DTMU -Ox 
MES member php 


甩 A ~、 
页 用 户 登录 用 户 注册 资料 修改 密码 
pp ] 
掌上 电脑 
数码 8 机 
图 9 程 
名 牌 手机 


KI vy [RRLFER 


图 4-67 更 新 成 功 的 页 面 
< 次 4.4.3 ) 修 改 资料 测试 
编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 ， 测 试 的 步 又 如 下 : 


四 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/memberindex.php， 打 开 index.php 
文件 。 在 该 页 面 中 进行 登录 。 登 录 成 功 后 进入 welcome.php 页 面 ， 在 welcome.php 页 面 单 击 
“修改 您 的 资料 ” 超 链 接 ， 转 到 userupdate.php 页 面 ， 如 图 4-68 所 示 。 
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用 户 注 册 丙 科 修改 


a | 
Ee 
六 “EE 
图 4-68 修改 design 用 户 注册 资料 
在 该 页 面 中 进行 一 些 修改 ， 然 后 单 击 “ 修 改 ” 按 钮 将 修改 结果 发 送 到 服务 器 中 。 


当 用 户 记录 更 新 成 功 后 , 浏览 器 会 转 到 userupdateok.php 页 面 中 , 显示 修改 资料 成 功 的 信息 ， 
同时 还 显示 了 该 用 户 修改 后 的 资料 信息 ， 并 提供 转 到 更 新 成 功 页 面 和 转 到 主页 面 的 链接 对 
象 ， 这 里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “ 重 新 修改 ”按钮 转 到 更 新 成 功 页 面 ， 效 果 如 
图 4-69 所 示 。 


于 < 本 ~ a 
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图 4-69 更 新 成 功 
上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 制作 成 功 。 


才 1 4.5 ”查询 密码 功能 

用 户 注册 页 面 通常 会 设计 问题 和 答案 文本 框 ， 它 们 的 作用 是 当 用 户 忘 记 密 码 时 ， 可 以 
通过 这 个 问题 和 答案 到 服务 器 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提 供 的 答案 和 数 
据 库 中 答案 是 否 相同 ， 如 果 相 同 ， 则 可 以 找 回 遗 失 的 密码 。 
< GT) 查询 密码 页 面 


本 节 主 要 制作 密码 查询 页 面 lostpassword.php， 具 体 的 制作 步骤 如 下 : 
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加 执行 菜单 栏 “文件” 一 “新 建 ”命令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpassword.php 
的 网 页 并 保存 。lostpassword.php 页 面 是 用 来 让 用 户 提交 要 查询 遗失 密码 的 用 户 名 的 页 面 。 


该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 如 图 4-70 所 示 。 


二 cvamppintdecs\member\: 
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图 4-70 lostpassword.php 页 面 
在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ， 在 “表单 名 
称 ” 文 本 框 中 输入 form1， 在 “动作 ”文本 框 中 输入 showquestion.php 作 为 该 表单 提交 的 对 
象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作 为 该 表单 的 提交 方式 ， 接 下 来 将 输入 用 户 
名 的 文本 域 命名 为 inputname， 如 图 4-71 所 示 。 


属性 
加 表单 ID 动作 [shovqoeztion php ] 局 上 标 )| ~ 类 CC) [无 _ 加 
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一 字符 宽度 0) | 类 型 四 单行 6) OS 行 0) OF) 。 关 C) 无 四 
fname | 景 多 字符 数 | 初 焕 值 I) | 多 

口 林 用) 
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图 4-71 设置 表单 提交 的 动态 属性 
其 中 ， 表 单 属性 设置 面板 中 的 主要 选项 作用 如 下 : 
(1) 在 “表单 ID” 文 本 框 中 输入 标志 该 表单 的 惟一 名 称 ， 命 名 表单 后 就 可 以 使 用 脚 
本 语言 引用 或 控制 该 表单 如果 不 命名 表单 , 则 Dreamweaver 使 用 语法 forml、 form2、.…. 
生成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 n 的 值 。 
(2) 在 “方法 ”下 拉 列 表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。POST 方 法 将 
在 HTTP 请 求 中 嵌入 表单 数据 。GET 方 法 将 表单 数据 附加 到 请 求 该 页 面 的 URL 中 ， 是 
默认 设置 ， 但 其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选择 POST 方法 。 
(3) “目标 ”下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 : 


_blank 在 未 命名 的 新 窗口 中 打开 目标 文档 。 
_parent 在 显示 当前 文档 的 窗口 的 父 窗 口中 打开 目标 文档 。 
_self 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 
_top 在 当前 窗口 的 窗 体内 打开 目标 文档 .此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 
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即使 原始 文档 显示 在 框架 中 。 


用 户 在 lostpassword.php 页 面 中 输入 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 这 时 会 通过 表单 
将 用 户 名 提交 到 showquestion.php 页 面 中 , 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 对 
应 的 提示 问题 并 显示 在 showquestion.php 页 面 中 ， 使 用 户 可 以 在 该 页 面 中 输入 问题 的 答案 。 
下 面 就 制作 显示 问题 的 页 面 。 

辆 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ,输入 网 页 标题 “查询 问题 ”， 执 行 菜单 栏 “ 文 
件 ” 一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion.php。 

国 在 Dreamweaver 制 作 静 态 网 页 ， 完 成 的 效果 如 图 4-72 所 示 。 


二 cvampp\ntdocs\member\showcuestion php (XHTML -Ox 
FR nymenser php 于 
产品 分 类 特别 推荐 “ 
a 查询 问 是 
esd ji 1 
图 | 得 | | 四 
各 多 手机 i: 1 
Le | 
7 
+ 这 网 六 品 语 用 户 名 个 存在: 
和 确定 订购 
3 网 上 付款 | 
4 填写 信息 
5 答 收 产品 
和 
RE 
Co ee | » 
I> Vo 本 Eom tfornl 而 目 目 国 6%x 3 


图 4-72 showquestion.php 静态 设计 
加 在 “文档 ”窗口 中 选中 表单 对 象 ， 在 其 对 应 的 “属性 ”面板 中 ，“ 动 作 ” 文 本 框 
中 输入 showpassword.php 作 为 该 表单 提交 的 对 象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 
作为 该 表单 的 提交 方式 ， 如 图 4-73 所 示 。 接 下 来 将 输入 密码 提示 问题 答案 的 文本 域 命名 为 
inputanswer。 


动作 |showpassword php 
力 法 |Posr 引 编码 关 型 


画 | = 字符 宽度 0) | | 类 型 单行 6) ” 〇 多 行 史 。 〇 过 吗 P) 类)| 
linputanswer | 景 多 字符 数 | 初始 值 I) | 19 
口 拓 上 
口 R 污 四 


图 4-73 设置 表单 提交 的 属性 
四 执行 菜单 栏 “ 窗 口 ” 一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 国 按 钮 ， 
在 弹出 的 下 拉 菜 单 中 选择 “记录 集 ( 查询) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 
在 该 对 话 框 中 进行 如 下 设置 : 
@@ 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作 为 该 记录 集 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连接 对 象 为 nymember。 
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@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 mnember。 

@ 在 “ 列 ? 栏 中 选中 * 选 定 的 ” 单 选 按钮 , 然后 从 下 拉 列 表 框 中 选择 username 和 question 。 
@ 在 “筛选 ” 栏 中 ,设置 记录 集 过 滤 的 条 件 为 username= 表 单 变 量 /inputname， 表 示 
根据 数据 库 中 username 字 段 的 内 容 是 否 和 从 上 一 个 网 页 中 的 表单 中 的 inputname 表 单 对 


完成 后 的 设置 如 图 4-74 所 示 。 


图 4-74 “记录 集 ” 对 话 框 
国 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 关 闭 该 对 话 框 。 返 回 到 “文档 ” 
窗口 。 
贺 将 Recordsetl 记 录 集 中 的 question 字 段 绑 定 到 页 面 上 相应 的 位 置 ， 如 图 4-75 所 示 。 


盖 cvampp\ntdocs\member\showauestion php perMD” Ss 
| 
产品 分 类 特别 推荐 

次 上 出 查询 问题 

OE i 

图 各 得 国 

机 1 和: 

购 和 8 流程 1 
万 章 

工 达 购 产品 读 用 户 名 不 存在 ! 一 

2 .确定 订购 

3. 网 上 付款 

4 填写 信息 

5 签收 产品 
本 C 一 二 普 半 ~ 
i 一 | 
[Ky bay table & fare #fornl 目 目 国 ess xszv 

图 4-75 ” 绑 定 字段 


国 执行 菜单 栏 “ 插 入 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 插入 一 个 表单 隐藏 
域 ， 然 后 将 该 隐藏 域 的 名 称 设置 为 username. 

国 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记 录 集 中 的 username 字 段 绑 定 到 
该 表单 隐藏 域 中 ， 如 图 4-76 所 示 。 
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ts 


格式 : 无 了 
MEY php echo $row_Recordsetl[ usen 


图 4-76 添加 表单 隐藏 域 


; 当 用 户 输入 的 用 户 名 不 存在 时 ， 
。 就 需要 设置 隐藏 区 域 。 


Ce 


即 记录 集 Recordset1 为 空 时 ， 就 会 导致 该 页 面 不 能 正常 显示 , 这 


在 “文档 ”窗口 中 选中 当 用 户 输入 的 用 户 名 存在 时 显示 的 内 容 即 整个 表单 ， 然 后 


单 击 “服务 器 行为 ”面板 上 睹 按钮 ， 在 弹出 的 下 拉 菜 单 中 执行 “显示 区 域 ”一 “如 果 记 录 
集 不 为 空 则 显示 区 域 ”命令 ， 则 会 打开 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 ， 在 该 对 话 框 
中 选择 记录 集 对 象 为 Recordset1。 这 样 只 有 当 记 录 集 Recordset1 不 为 空 时 ， 才 显示 出 来 ， 如 
图 4-77 所 示 。 设 置 完 成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 


图 4-77 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 
在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 ! ”， 并 为 这 些 内 容 
设置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 器 行为 ， 这 样 当 记录 集 Recordset1 
为 空 时 ， 显 示 这 些 文本 ， 完 成 后 的 网 页 如 图 4-78 所 示 。 
寺 cvwamppWtdocswnembershowquestion php pHTMD -Ox 
| GEEED sender ni 
;产品 分 类 
EE ”查询 问题 
数码 HB 机 


图 革 程 
名 由 手机 


1. 选 购 产品 
2. 确 定 订购 


:了 网 上 付款 

:4 填写 信息 FE 

:5 等 收 产品 也 
4 w 


vey Roe ls) Ma a EEC LE 且 [zc 目 目 呈 上 227v 


图 4-78 设置 隐藏 区 域 
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< 4.5.2 ) 完 善 查 询 功能 


当 用 户 在 showquestion.php 页 面 中 输入 答案 ， 单 击 “ 提 交 ” 按 钮 后 ， 服 务 器 就 会 把 用 户 
名 和 密码 提示 问题 答案 提交 到 showpassword.php 页 面 中 。 

下 面 介绍 如 何 设计 该 页 面 ， 具 体制 作 步 又 如 下 : 

加 执行 菜单 栏 “ 文 件 ” 一 “新 建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 
showpassword.php 的 网 页 并 保存 。 

贺 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 完成 如 图 4-79 所 示 的 静态 部 分 。 


示 cvampp\htdocs\memben\showpassword php ootTMU" 


< 了 
首 页 | 用 户 登录 用 户 注 册 资料 修改 


产品 分 类 
学 上 电脑 查询 结果 
Lalla 对 不 起 您 输入 的 答案 不 正确 ,请 单 击 这 里 重新 输入 
图 Mh 程 
名 牌 手机 用 户 : 
购物 流程 E22 


1 选 购 产品 单 击 这 里 重新 登录 
2 .确定 订购 
3. 网 上 付款 
4 可 
2 


图 4-79 showpassword.php 静态 设计 

园 执行 菜单 栏 “ 窗 口 ” 一 “ 绑 定 ” 命 令 ， 打 开 “ 绑 定 ”面板 ， 单 击 该 面板 上 [ 国 按钮 ， 
在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

贺 在 该 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 Recordset1 作 为 该 记录 集 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 mymember。 
@ 
@ 


从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member。 

在 “ 列 ” 栏 中 先 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 选择 字段 列表 框 中 的 username、 
password 和 answer 等 3 个 字段 就 行 了 。 

在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 : answer= 表 单 变 量 /inputanswer， 表 示 根 据 
数据 库 中 answer 字 段 的 内 容 是 从 上 一 个 网 页 中 的 表单 中 的 inputanswer 表 单 对 象 传 
递 过 来 的 信息 是 否 完全 一 致 来 过 滤 记 录 对 象 。 


完成 的 设置 情况 如 图 4-80 所 示 。 
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ss | 


图 4-80 设置 “记录 集 ” 对 话 框 
单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 
四 将 记录 集中 username 和 password 两 个 字段 分 别 添 加 到 网 页 中 ， 如 图 4-81 所 示 。 


DEFTZT 
“0G 9 
ET Wi WP -Rm A Ra E 
国 


图 4-81 加 入 的 记录 和 集 效果 


同样 需要 根据 记录 集 Recordset1 是 否 为 空 , 为 该 网 页 中 的 内 容 设置 隐藏 区 域 的 服务 
器 行为 。 在 “文档 ”窗口 中 ， 选 中 当 用 户 输入 密码 提示 问题 答案 正确 时 显示 的 内 容 ， 然 后 
单 击 “ 服 务 器 行为 ”面板 上 [区 坊 和 钮 ， 在 弹出 的 下 拉 菜 单 中 执行 “显示 区 域 ” 一 “如 果 记 录 
集 不 为 空 则 显示 区 域 ” 命 令 ， 打 开 “ 如 果 记录 集 不 为 空 则 显示 ”对 话 框 ， 在 该 对 话 框 中 选 
择 记录 集 对 象 为 Recordset1. 这 样 只 有 当 记 录 集 Recordset1 不 为 空 时 , 才 显 示 出 来 , 如 图 4-82 
所 示 。 设 置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 


图 4-82 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 
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国 在 网 页 中 选择 当 用 户 输入 密码 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 内 容 
设置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ” 隐 藏 区 域 服务 器 行为 ， 这 样 当 记录 集 Recordsetl 
为 空 时 ， 显 示 这 些 文本 ， 如 图 4-83 所 示 。 


如 果 记 录 集 为 空 则 旦 示 
记录 集 : |Recordsetl 四 EE 
取消 
帮助 


图 4-83 “如 果 记 录 集 为 空 则 显示 ”对 话 框 
贺 完成 后 的 网 页 如 图 4-84 所 示 。 执 行 菜单 栏 “ 文 件 ”一 “保存 ”命令 ， 将 该 文档 保 


存 到 本 地 站 点 中 。 
人 Ba-. 国 OLLelx 
showpasswordphp x member memberuhowgarsword PN 
er ph Ea 
| 代码 | 拆 分 上 设计 ]， 关 时 视图 标题 : 密码 视图 “ 
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.填写 信息 了 SR PHP| 
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图 4-84 完成 后 的 网 页 效果 图 
463) 查询 密码 功能 
开发 完成 查询 密码 的 功能 之 后 ， 就 可 以 测试 执行 的 情况 ， 进 行 测试 的 步骤 如 下 : 


贺 启动 浏览 器 , 在 地 址 中 输入 http://127.0.0.1/member/index.php， 打开 index.php 首 页 ， 
单 击 该 页 面 中 的 “ 找 回 密码 ” 超 链接 进入 找 回 密码 页 面 ， 如 图 4-85 所 示 。 
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户 名 信息 


ES 
看 | 蕊 | 会 | 丰 | 因 |htt 


CO riess 


用 户 注册 


a 
资料 修改 


产 St 明 ; 三 性 知 了 于 六 ,1007 弹 训 女 持 可 到 4 
和 寺村 不 手写 PI 家 着 妇 关 等 村 点 。 


估价 : san0 


SN: ¥um 


Me。 


图 4-85 输入 要 查询 的 用 户 名 


当 用 户 进 入 密码 查询 页 面 lostpassword.php 后 ， 输 入 并 向 服务 器 提交 自己 注册 的 用 
当 输 入 不 存在 的 用 户 名 ,并 单 击 “提交 ”按钮 ， 则 会 转 到 showqeustion.php 页 面 ， 


该 页 面 显 示 出 用 户 名 不 存在 的 错误 信息 ， 如 图 4-86 所 示 。 


三 350 安 全 避 壤 旺 71 


所 || 必 j| 会 || 太 | 四 


LE 口 aoas 
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学 
资料 修改 密码 查询 


图 4-86 输入 用 户 不 存在 


如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 按 钮 。IE 浏 览 器 会 
自动 转 到 showquestion.php 页 面 ， 如 图 4-87 所 示 。 下 面 就 应 该 在 showquestion.php 页 面 中 输 
入 问题 答案 ， 测 试 showquestion.php 网 页 的 执行 情况 。 
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站 


专线 会友 名 htipW/127.0.0.1 


图 4-87 ”showqeustion.php 网 页 效果 图 


加 在 这 里 可 以 先 输入 一 个 错误 的 答案 ， 检 查 showpassword.php 是 否 能 够 显示 问题 答 
案 不 正确 时 的 错误 信息 ， 如 图 4-88 所 示 。 
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掌上 电话 查询 车 只 
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国 : 浊 各 

SM 

购物 流程 间 

ieo 

1 过 9 产品 

Bi] 

了 网 上 付款 
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图 4-88 出 错 信息 


如 果 在 showqeustion.php 网 页 中 输入 正确 的 答案 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 浏 览 器 
就 会 转 到 showpassword.php 页 面 ， 并 显示 出 该 用 户 的 密码 来 ， 如 图 4-89 所 示 。 
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图 4-89 showpassword.php 页 面 
四 上 述 测 试 结 果 表 明 ， 密 码 查询 系统 已 经 成 功 制作 。 
用 户 管理 系统 的 常用 功能 都 已 经 设计 并 测试 成 功 ， 读 者 如 果 需 要 将 其 应 用 到 其 他 的 网 


站 上 ， 只 需要 修改 一 些 相关 的 文字 说 明 及 背景 效果 ， 就 可 以 完成 用 户 管理 系统 的 制作 ， 在 
注册 的 字段 采集 时 也 可 以 根据 网 站 的 需求 进一步 增加 数据 表 字 段 的 值 。 
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第 章 


全 程 实例 三 : 新 闻 管 理 系统 


新 闻 管 理 系统 主要 实现 对 新 闻 的 分 类 、 发 布 ， 模 拟 了 一 般 新 闻 媒 介 的 发 布 的 过 程 。 新 
闻 管 理 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 行 业 信 
息 、 企 业 状况 以 及 需要 了 解 的 一 些 知识 。PHP 实 现 这 些 功 能 相对 比较 简单 ， 涉 及 的 主要 操 
作 就 是 访问 者 的 新 闻 查 询 功能 ， 系 统管 理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功 能 ， 本 章 就 介绍 
使 用 PHP 开 发 一 个 新 闻 系 统 的 方法 。 


本 章 的 学 习 重 点 : 
@ 新 闻 管 理 系统 网 页 结构 的 整体 设计 
新 闻 系 统 数 据 库 的 规划 
新 闻 管 理 系统 前 台新 闻 的 发 布 功能 页 面 的 制作 
新 闻 管 理 系统 分 类 功能 的 设计 
新 闻 管 理 系统 后 台新 增 、 修 改 、 删 除 功能 的 实现 


1 5.1 ”新 闻 管理 系统 的 规划 


使 用 PHP 开 发 的 新 闻 管 理 系统 ， 在 技术 上 主要 体现 为 如 何在 首页 上 显示 新 闻 内 容 ， 以 
及 对 新 闻 及 新 闻 分 类 的 修改 和 删除 。 一 个 完整 的 新 闻 管理 系统 共 分 为 二 大 部 分 动态 网 页 ， 
一 个 是 访问 者 访问 新 闻 的 动态 网 页 ， 另 一 个 是 后 台 管 理 者 对 新 闻 进 行 编辑 的 动态 网 页 。 
多 5.1.1 ) 系 统 的 页 面 设计 


在 本 地 站 点 上 建立 站 点 文件 夹 hews， 用 于 存放 将 要 制作 的 新 闻 管 理 系统 文件 夹 和 文 
件 ， 如 图 5-1 所 示 。 


Ez P| 


图 5-1 站 点 规划 文件 夹 和 文件 

本 系统 页 面 共 有 11 个 ， 整 体系 统 页 面 的 功能 与 文件 名 称 如 表 5-1 所 示 。 
表 5-1 新闻 管理 系统 网 页 功能 

功能 


显示 新 闻 分 类 和 最 新 新 闻 页 面 
type.php 显示 新 闻 分 类 中 的 新 闻 标题 页 面 


admin login.php 
admin php 
news_add.php 
news_upd.php 
news delphp 
type addphp 
bpe_ updphp 
type del php 


人 5.1.2 ) 系 统 的 美工 设计 


本 新 闻 管 理 系统 实例 在 色调 上 选择 蓝 色 作 为 主 色 调 ， 网 页 的 美工 设计 相对 比较 简单 ， 
创意 为 一 个 人 在 读 取 国 内 外 的 新 闻 ， 完 成 的 新 闻 系 统 首 页 index.php 效 果 如 图 5-2 所 示 。 


显示 

显 如 
newscontent.php 显示 新 闻 内 容 页 面 

管 

入 ee 


页 面 
[em | 
[epepm | 
| newsconentphp | 
[aaminloginphp | 
[aminpip | 
| newsaddpm | 
| newspdmp | 
| newsdmm | 
| epeaddupm | 
| epepdpm | 
[Lepedpm | 
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网 站 开发 全 程 实例 (第 2 版 ) 
er 


oa 


系 殊 关 页 | 最 新 新 闻 新 闻 俱 类 二 后台 千 理 


忆 .PHP 新闻 管 理 系统 


图 5-2 首页 index.php 效果 图 
新 闻 管理 系统 的 后 台 也 是 重要 的 ， 实 例 登 录 后 台 的 效果 如 图 5-3 所 示 。 


em 加 昌 路 


图 5-3 后 台 管 理 页 面 效 果 图 


) 5.2 ”系统 数据 库 的 设计 
容 、 管 理 员 账 号 和 密码 的 数据 库 文 件 ， 


个 新 闻 管 理 系统 ,首先 要 设计 一 个 储存 新 闻 内 容 、 


制作 一 个 
方便 管理 人 员 对 新 闻 数 据 信息 进行 管理 和 完善 
< 5.2.1 ) 新 闻 数 据 库 设计 

新 闻 管理 系统 需要 一 个 用 来 存储 新 闻 标 题 和 新 闻 内 容 的 新 闻 信息 表 news， 还 要 建立 一 个 
新 闻 分 类 表 newstype 和 一 个 管理 信息 表 admin。 


制作 的 步骤 如 下 : 
在 phpmyAdmin 中 建立 数据 库 news， 单 击 电 数 据 库 命令 打开 本 地 的 “数据 库 ” 管 理 
单 去 后 面 的 数据 库 类 型 下 拉 菜 


凯 
页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 news 
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第 5 章 全 程 实例 三 ， 新 闻 管理 系统 弄 归 ， 
oS 


单 ， 在 弹出 的 选择 项 中 选择 utf8_bin 选 项 ， 单 击 “创建 ”按钮 ， 返回“ 常规 设置 ”页 面 ， 
在 数据 库 列 表 中 就 已 经 建立 了 news 的 数据 库 ， 如 图 5-4 所 示 。 


EE BW -I x 
| 避 | 舍 大 加 [mp//127001 


a PY 


phpMyAdmin 
EFT 


a 
itemmation schems 三 天 号 二 入 蛋 订 四 太 -|e 画 “ 127100 1 We TPIP 
ne eh | 
+ | 
i . Er 
让 
-= ee 
Pd phpweb Ws -Lg -Cnnere spaed 加 | 
EE FE 
wb 3 0% 加 | 

a 

ee 


-基本 癌 户 汪 上 本 :Jomysg - mysqlnd 


图 5-4 创建 news 数据 库 


单 击 左边 的 news 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 
名 news、newstype 和 admin， 即 创建 3 个 数据 表 。 创 建 的 news 数 据 表 如 图 5-5 所 示 。 


phpMyAdmin 上 上 
CE WE ET 
(tm9) ， 国 | GE 2 a 
mm rt) 页 至 仙 TOJINCREMENT .0 四 有 坟 7 
3 tedl 
各 men seo 2 rt rn Hs i rs 
书 -1 mnber 问 3 new pe 。 vcdwD9) am bm EE ia On Pris 
Pamy mmcomont tod lb 是 NULL Nx ON DIE ES 
TIS 目 5 nowdate date EE ONS Fv 
i Som eumor racerpgl vss be NL I 
了 mawe 

ampe 2 sm 目 3 At 日 We 户 # 半 桓 叶 -三 穴 引 区 空间 

Romunce_ scheme 国信 六 家 

a pee EEETY TTT TT 

al Ba [1 | Fre TE © TRA DF 之 5 [oom Ej] (BD 

pg webaun 村 

| ss 
em 
的 和 0 字 和 区 
sl 2 者 | 


图 5-5 创建 的 news 数据 表 
输入 数据 域名 以 及 设置 数据 域 位 的 相关 数据 ， 数 据 表 news 的 字段 说 明 如 表 5-2 所 示 。 


表 5-2 ”新 闻 数 据 表 news 


字段 名 称 
主题 编号 news_id 
新 闻 标题 news_title 

新 闻 分 类 编号 news_type 

新 闻 内 容 news_content 
新 闻 加 入 时 间 news_date 
编辑 者 news_author 
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创建 newstype 数 据 表 ， 用 于 储存 新 闻 分 类 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 
相关 数据 ， 如 图 5-6 所 示 。 


phpMyAdmin 

as0Ts - 

[CE 六 

加 ape 大 mm 

口 2 qpe meme varcharEn) us omnesld 二 三 

1 加 3 2f 和 5 百 和 /tire 日 NM 六 十 面 间 司 # 引 卫 实 
亲 全 六 二 


EE 


PT EE 
再 一 ATO INCREMENT 必 区 和 全 开除 岂 主 灶 直下 


7 


rrr 
个 部 拉 生 于 志江 日 于 六 


newstype 数 据 表 的 字段 及 说 明 如 表 5-3 所 示 。 
表 5-3 ”新 闻 分 类 数据 表 newstype 
字段 名 称 数据 类 型 字段 大 小 必 填 字段 


ET | epeid [mcr |un | 是 | 
新 闻 分 类 | apename |varcHarg | | 是 | 


贺 创建 admin 数 据 表 , 用 于 后 台 管 理 者 登录 验证 用 , 输入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 图 5-7 所 示 。 


| @ 00S 7 
拟 || 弓 | 会 || 太 | @ hrpv112700.1Phprmya 


入 127 00 Vehpmyadmin/sp, x 


phpMyAdmin 瑟 
ROTe 旧 3 怠 吉 和 月 Sa 和 要 革 b 和 A 加 Sd 司 SA 成 扫 人 生 WE Y 更 多 
过 人 用 的 表 ) 百 后 经 作 
国生 ode 加 1 iT) 亚 天 AUTO_INCREMENT 汉人 以 改 雹 出 祭 疙 三 建 困难 - 
-sinformation_scheme 时 
重 加 mnier 局 2 usemame varehors0) wis gororal dl 下 到 的 下 回 刚 搞 浓 主 久 而 稚 一 
-mysql vv 
9 news El 3 password varcharf50) ut5_gororal ci 于 到 态 他 故国 出 从 户主 福 国 惟一 
i 二 六 
a 人 日 4 壬 pm 且 澳 少 他 疏 生出 六 大 同时 - 司 守卫 空间 
出 同 newstypa 国 全 文 构 系 
市 -peromancs_ schema FET 
WH-。 phpmyadmin 十 衬 拭 司 © 二 rr 
站 《二 所 二 于 产 引导 站 于 去 开业 自 Ca 
二 二 st 
唐 了 wabaun 
Row statistics 
Ee 着 式 a 
| 竺 所 用 则 ts0 general oi 
号 计 2 KB 行 趣 1 


图 5-7 创建 的 admin 数据 表 
admin 数 据 表 的 字段 及 说 明 如 表 5-4 所 示 。 
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表 5-4 ”管理 信息 数据 表 admin 


字段 名 称 数据 类 型 字段 大 小 


意义 


主题 编号 
用 户 名 username 
| 密码 | password 


在 创建 上 述 的 3 个 数据 表 时 ，, 其 中 有 涉及 到 新 闻 保存 时 的 时 间 保 存 问题 , 使 用 PHP 实 现 
获取 系统 默认 即时 时 间 ， 可 以 使 用 两 种 方法 ， 一 种 是 在 网 页 PHP 中 用 date0 和 time() 函 数 实 
现 ， 另 一 种 是 直接 在 MySQL 数 据 库 中 的 NowO 时 间 ， 考 虑 到 因为 后 期 数据 量 大 需要 减少 服 
务 器 的 工作 量 ， 我 们 优先 采用 在 网 页 使 用 PHP 获 取 时 间 的 方法 ， 具 体 的 实现 方法 在 新 增 新 
闻 页 面 的 设计 时 会 讲 到 。 


< 522 ) 创 建 系统 站 点 


在 Dreamweaver CC 中 创建 一 个 “新 闻 管理 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数 据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 5-5 所 示 。 


表 5-5 ”站 点 设置 参数 


站 点 名 称 news 


MySQL 服 务 器 地 址 
管理 账号 / 密码 
数据 库 名 称 bs | 


创建 news 站 点 具体 操作 步骤 如 下 : 


首先 在 C:\xampP\htdocs 路 径 下 建立 news 文 件 夹 ( 如 图 5-8 所 示 ) ， 系 统 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 底下。 


回避 一 | 
GO Hh, eer» emop ，hdca， E25 万 
XH 3 IRM ar) 

Er 


图 5-8 建立 站 点 文件 夹 news 
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运行 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打开“ 管 
理 站 点 ”对 话 框 ， 如 图 5-9 所 示 。 


图 5-9 “管理 站 点 ”对 话 框 
加 对 话 框 的 上 面 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 角 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 news” 对 话 框 ， 人 


| 去 ee 让 是 网站 中 本 用 的 了 仁和 扩 类 Dreamweav - 
一 贡生 内 中 四 和 本 2 a 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : [er 
本 地 站 点 文件 夫 : [CanopPtocs ens\ 目 
| | 
| 
| 
0 [ 钴 ][ 器 
CC 一 J 


图 5-10 ”建立 news 新 闻 站 点 


单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 E， 打 开 “ 基 本 ” 
选项 卡 进行 如 图 5-11 所 示 的 参数 设置 。 
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7- |) 


ET | 
Na Er es | 
| 


“基本 ”选项 卡 设置 


图 5-11 


设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL， 表示 是 使 用 PHP 开 发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-12 所 示 。 


PT 
让 Cm md 本 
bs 二 程 服 芳 沪 
， 高 如 拘 维 护 同 上 信息 
口 保 丰 时 自动 将 文件 上 传 到 服务 器 | 
口 自用 文件 双 出 功能 ' 
也 打开 叉 任 之 前 了 出 | 
了 bh; | || 
| [5 | | 
| 
测试 服务 深 | 
rr | | 
己 [mm | | 
E22 CC | 


图 5-12 设置 “高 级 ”选项 卡 


国 单 击 “ 保 存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 


所 示 。 


您 将 在 此 位 置 寺 择 予 载 Web 上 的 页 面 的 服务 器 .此 对 活 框 的 设 团 末 自 
Internet 服务 提供 商 (1SP) 或 Web 管 尘 员 。 


六 您 无 要 寺 所 化 帮 牧 。 各 时 要 过 当 到 W 由 并 总 


图 513 选择 “测试 ” 复 选 框 
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复 选 框 ， 如 图 5$-13 


Oe 
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单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 
PR ha dis et et 
Dreamweaver CC 测试 用 户 管理 系统 网 页 的 网 站 环境 设置 。 


人 5.2.3 ) 数 据 库 连接 
建立 数据 库 后 ， 要 在 Dreamweaver CC 中 连接 news 数 据 库 , 连接 新 闻 管理 系统 与 数据 库 
的 步骤 如 下 : 


将 设计 的 本 章 文件 复制 到 站 点 文件 夹 下 ， 打 开 index.php， 如 图 5-14 所 示 。 


A ee A | 


所 5 einaeas/top ei 
二 Se fee of 有 


区 图 目 仔 cr) 
[INiGSE 原 折 oO 


图 5-14 打开 网 站 首页 
贺 单 击 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “数据 库 ” 面板 。 在 该 面板 上 
单 击 “+” 图 标 ， 并 在 打开 的 下 拉 菜 单 中 选择 ”MySQL 连接 ”选项 ， 如 图 5-15 所 示 。 


图 5-15 选择 “MySQL 连接 ” 

国 在 “MySQL 连接 ”对话 框 中 ， 输 入 “连接 名 称 ” 为 ews、“MySQL 服 务 器 ”名 
为 localhost、“ 用 户 名 ”为 root、 密 码 为 空 。 选 取 所 要 建立 连接 的 数据 库 ， 可 以 单 击 “ 选 取 ” 
按钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 。 选择 刚 建立 的 范例 数据 库 news, 具体 内 容 设置 如 
图 5-16 所 示 。 
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MySQL 服务 器 : Localhost 
用 户 名 : root 


密码 
数据 库 : nevs 


图 5-16 设置 MySQL 连接 参数 


单 击 “ 测 试 ” 按 钮 测试 与 MySQL 数 据 库 的 连接 是 否 正确 ， 如 果 正 确 则 弹出 一 个 提 
示 消 息 框 (如 图 5-17 所 示 ) ， 这 表示 数据 库 连 接 设 置 成 功 了 。 


图 5-17 设置 成 功 


加 单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数 
据 库 ， 如 图 5-18 所 示 。 


轩 newstype 
办 视图 
寺 预存 过 程 


< | > 
图 5-18 绑 定 的 数据 库 news 


2 53 新闻 系统 页 面 


新 闻 管 理 系 统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 用 来 访问 的 首页 新 闻 主 页 面 
index.php， 新 闻 分 类 信息 页 面 type.php， 新 闻 详细 内 容 页 面 newscontent.php。 


< 531 ) 新 闻 系统 主页 面 设计 


在 本 小 节 中 主要 介绍 新 闻 管理 系统 的 主页 面 index.php 的 制作 , 在 index.php 页 面 中 主要 有 
显示 最 新 新 闻 的 标题 , 加 入 时 间 ， 显示 新 闻 分 类 , 单 击 新 闻 中 的 分 类 进入 分 类 子 页 面 查看 新 闻 
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CRs 
等 功能 。 
制作 的 步骤 如 下 : 


打开 刚 创建 的 index.php 页 面 ， 输 入 网 页 标题 “新 闻 首页 ”， 执 行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 将 网 页 保存 。 

用 单 击 鼠 标 创建 表格 的 第 1 行 单元 格 ， 输 入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ， 
标签 ， 将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index.php 页 面 使 用 的 数据 表 是 
news 和 newstype， 单 击 “ 应 用 程序 ”面板 中 的 “ 绑 定 ”标签 上 的 国 按 钮 ， 在 弹出 的 菜单 中 
选择 “记录 集 (查询 ) ”选项 ， 在 该 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 Recordset1 作 为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-19 所 示 。 


图 5-19 “记录 集 ” 对 话 框 
绑 定 记录 集 后 ， 将 记录 集 的 相关 字段 插入 至 index.php 网 页 的 适当 位 置 ， 如 图 5-20 


所 示 。 


画 cwamppwhdocsnewvrderphp” 
EY re np 
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图 5-20 插入 至 index.php 网 页 中 
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由 于 要 在 index.php 这 个 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 ， 而 目前 的 设 定 
则 只 会 显示 数据 库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ”的 命令 ， 
选择 {Recordsetl.type_name} 所 在 的 行 ， 如 图 5-21 所 示 。 

国 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 [出 按钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 选中 “所 有 记录 ” 单 选 按 
钮 ， 如 图 5-22 所 示 。 


有 


有 


{Recordsetl. type_name]} 


图 5-21 选择 要 重复 显示 的 一 列 图 5-22 ”选择 一 次 可 以 显示 的 次 数 

国 单 击 “确定 ”按钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

除了 显示 网 站 中 所 有 新 闻 分 类 标题 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链 
接 来 实现 详细 内 容 的 阅读 ， 为 了 实现 这 个 功能 首先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字 
段 ， 如 图 5-23 所 示 。 

国 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 
话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 type.php， 如 图 5-24 所 示 。 


图 5-23 选择 新 闻 分 类 标题 图 5-24 选择 链接 文件 


国 单 击 “确定 ”按钮 ， 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 为 
type.php?id=<?php echo $row_Recordsetl['type_id']; ?>， 如 图 5-25 所 示 。 


《> mmL| 格式 中) | 无 四 类 无 ~ BI 汉 后 兰 兰 标题 D) 
本 cs mm 无 拉 技 0 Ori 和 TE -CO By 。 目标 6) ~ 


中 单元 格 。 水 平台 ) | 默认 7 不 摘 行 0) 门 、 背景 地 色 (6) 全 | 页 面 属性 ..- 
一 一 光春 中 目 A ”7 高 | 标题 中 本 


图 5-25 “参数 ”对 话 框 
单 击 “确定 ”按钮 回 到 编辑 页 面 ， 主 页 面 index.php 中 新 闻 分 类 的 制作 已 经 完成 ， 
最 新 新 闻 的 显示 页 面 设计 效果 如 图 5-26 所 示 。 
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EY nos pp 5 


c PHP 新 闻 管 理 系统 
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图 5-26 ”设计 结果 效果 图 

单 击 “ 应 用 程序 ”面板 中 的 “ 绑 定 ” 标 签 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 
“记录 集 (查询 ) ”选项 ， 打 开 “ 记 录 集 ”对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文本 框 中 输入 Rel 作 为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

@ “排序 ”设置 为 news_id 降 序 方式 。 

完成 的 设置 情况 如 图 5-27 所 示 。 


莉 E 


一 一 = 


图 5-27 


绑 定 “记录 集 ” 后 ， 将 记录 集 的 字段 插入 至 index.php 网 页 的 适当 位 置 。 

由 于 要 在 index.php 页 面 显 示 数 据 库 中 部 分 新 闻 的 信息 ， 而 目前 的 设 定 则 只 会 显示 
数据 库 的 第 一 笔 数 据 , 因此 ,需要 加 入 “服务 器 行为 "中 的 “重复 区 域 " 的 设置 , 单 击 index.php 
页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 图 5-28 所 示 。 
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二 cvampp\ntdocs\news\indecphp* So 
ph 


[KI voy table 


a Ta a 


a 


四 - [DD 日 目 国 sex 
图 5-28 单 击 选择 需要 重复 的 选区 
单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 


菜单 中 选择 “重复 区 域 ” 选项， 在 弹出 的 “重复 区 域 ”对 话 框 中 设置 要 重复 的 记录 条 数 ( 例 
如 10 条 ) ， 如 图 5-29 所 示 。 


图 5-29 选择 一 次 可 以 显示 的 次 数 


国 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 
“重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 了 。 


i 较 由 于 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 
新 闻 标 题 链接 至 详细 内 容 来 阅读 ， 首 先 选取 文字 “查看 ”， 如 图 5-30 所 示 。 


| 
图 5.30 选择 新 闻 分 类 标题 “查看 ” 


在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 
话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 newscontent.php， 如 图 5-31 所 示 。 
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和 2014/12/8 14:32 
司库 骨 notes 2014/12/8 10:42 
[2 上 admin 2014/12/8 10:42 
回国 + BConnections 2014/12/8 1042 
国 阅 引 看 dam 2014/12/8 1042 
EE 下 images 2014/12/8 13:50 


由 证 和 目 indexphp 2014/12/8 13:50 。 PHP 文件 9KB 
[newscontentphp 201M7/9 800 PHP 文件 4KB 

曾 计算 册 目 bypephp 2011/7/9 7:53 PHP 文 件 BKB 

包 Acer (C3 

地 (D) 

本)  、 

a 
(NY: newscontent php > 


图 5-31 选择 链接 文件 


单 击 “确定 ”按钮 ， 设 置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 什 
newscontent.php?news_id=<?php echo Srow_Rel['news_id']; ?>。 将 参数 名 称 命名 为 news _id， 
如 图 5-32 所 示 。 


温 摇 汪汪 村 是 中 
加 - 昌 辐 目标 名 


he $row Rel [ners i 
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图 5-32 “动态 数据 ”对 话 框 
单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 当 记录 集 超过 一 页 ， 就 必须 要 有 “上 一 页 ”、 
“下 一 页 ”等 按钮 或 文字 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 分 页 ”的 功能 。 
“记录 集 分 页 ”按钮 位 于 “插入 ”工具 栏 的 “数据 ”组 中 ， 因 此 将 “插入 ”工具 栏 由 “ 常 
用 ”切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 分 页 ” 国 工 具 按钮 ， 如 图 $-33 所 示 。 这 里 要 说 明 
的 是 CC 版 本 中 也 需要 安装 扩展 才 会 有 此 操作 选项 ， 也 可 以 通过 “服务 器 行为 ”中 的 “记录 
集 分 页 ”实现 分 页 的 操作 。 


图 5-33 选择 “记录 集 分 页 ”选项 
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在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 
方式 “文本 ”， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 
如 图 5-34 所 示 。 
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图 5-34 添加 “记录 集 导航 条 ”页 面 
如 果 希 望 看 到 总 共有 多 少 记 录 ， 当 前 记录 是 第 几 条 ， 那 么 必须 插入 “记录 集 导 航 
状态 ”， 在 “插入 ”工具 栏 的 “数据 ”类 型 中 ， 单 击 “ 显 示 记录 计数 ”工具 按钮 [加 ,在 弹 
出 的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 
会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-35 所 示 。 


函 cwamppwdocsnewvirderphpr EE 


Sy evs hp 
NN 
Start your intenet es ASADAL 


图 5-35 添加 计数 器 
国 index.php 这 个 页 面 需要 加 入 “查询 ”的 功能 ， 这 样 新 闻 管理 系统 才 不 会 因 日 后 数 
据 太 多 而 有 不 易 访 问 的 情形 发 生 ， 设 计 如 图 5-36 所 示 。 
查询 主题 : [二 和 ] 
图 5-36 搜索 主题 设计 
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脸 


利用 表单 及 相关 的 表单 组 件 来 制作 以 关键 词 查询 数据 的 功能 ， 需 要 注意 图 $-36 所 示 的 内 容 都 在 一 个 


表单 之 中 ，“ 查 询 主题 ”后 面 的 文本 框 的 命名 为 keyword，“ 查 询 ” a 


国 在 此 要 将 之 前 建立 的 记录 集 Rel 作 一 下 更 改 , 打开 “记录 集 ” 对 话 框 ， 并 进入 “高 
级 ”设置 ， 在 原 有 的 SQL 语法 中 加 入 一 段 查询 功能 的 语法 : 


where news title like '%".S$keyword."%' 


那么 以 前 的 SQL 语 句 将 变 成 如 图 5-37 所 示 。 


图 5-37 修改 SQL 语句 
低估 3 全) 


其 中 like 是 模糊 查询 的 运算 子 ，% 表 示 任 意 字符 ， 而 keyword 是 个 变量 ， 分 别 代表 关键 词 。 


园 切换 到 代码 设计 窗口 。 找 到 Rel 记 录 集 相应 的 代码 并 加 入 如 下 代码 : 
$keyword=$_POST [keyword]; 


定义 keyword 为 表单 中 keyword 的 请 求 变 量 ， 如 图 5-38 所 示 。 


示 cvampp\htdocs\news\index php* 后 六 
EY ers php EG 
了 E 
二 国 
unction_exists("GetSQLVatuestring")) { 
function GetSQLVvatuestring(Sthevatue，StheType，StheDefinedvatue 
StheNotDefinedyatue = "") 
{ 
if (PHP_VERSION < 6) { 
$thevalue = get_magic_quotes_gpc() ? stripslashes($thevalue) : $thevalue 
} 
S$thevalue = function_exists("nysql_real_escape_string") ? 
mysql_real_escape_string($theValue) : mysql_escape_string($theValue) 
switch ($theType) { E 


图 5-38 加 入 代码 


以 上 的 设置 完成 后 ，index.php 系 统 主页 面 就 有 查询 功能 了 ， 先 在 数据 库 中 加 入 两 
条 新 闻 数 据 ， 可 以 按 下 F12 键 至 浏览 器 测试 一 下 是 否 能 正确 的 查询 。index.php 页 面 会 显示 
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TO 


© 
所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标 题 ， 如 图 5-39 所 示 。 


EE EE 


后 六 号 | | 文 [ 回 Pizzaolm= elv 


Er 


图 5-39 主页 面 浏览 效果 图 


在 关键 词 中 输入 “开通 ”并 单 击 “ 查 询 ” 按 钮 ， 结 果 显 示 在 查询 结果 页 面 中 只 包 
含有 关 “ 开 通 ”的 最 新 新 闻 主 题 ， 这 样 查询 功能 完成 了 ， 效 果 如 图 5$-40 所 示 。 


EE Ce 3 
和 志 全 | 全 | 太 四 WIE127001m BY 


上 回 wma 


5 PHP 新 闻 管 理 系统 


图 5-40 ”测试 查询 效果 图 


-532 ) 新 闻 分 类 页 面 设计 


新 闻 分 类 页 面 type.php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index.php 页 面 中 
的 任何 一 个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设计 效果 如 图 
5-41 所 示 。 
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图 5-41 新 闻 分 类 页 面 效果 
详细 的 操作 步骤 说 明 如 下 : 


加 执行 菜单 栏 “ 文 件 ” 一 “新 建 ” 命 令 创建 新 页 面 ， 输 入 网 页 标题 “新 闻 分 类 ”， 
执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 在 站 点 news 文 件 夹 中 将 该 文档 保存 为 type.php。 
园 新 闻 分 类 页 面 和 首页 面 中 的 静态 页 面 设 计 差 不 多 ， 在 这 不 作 详细 说 明 。 
type.php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news， 
单 击 “ 绑 定 ”面板 中 的 “增加 ”上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ” 
选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
在 “名 称 ” 文 本 框 中 输入 Recordset1 作 为 该 记录 集 的 名 称 。 
从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 
从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 
在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
设置 “筛选 ”的 条 件 为 : news_id=URL 参 数 /id。 
设置 “排序 ”方法 为 以 news_id 升 序 。 
设置 完成 后 单 击 “ 确 定 ” 按 钮 ， 如 图 5-42 所 示 。 


名 称 : Recordset1 


图 542 绑 定 记 录 集 设 定 
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绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 type.php 网 页 中 的 适当 位 置 ,如 图 5-43 所 示 。 


动 cvampo\ntdocsnewsype php* -Ox 
EY 


i EE 
图 543 插入 至 type.php 网 页 中 
国 为 了 显示 所 有 记录 ,需要 加 入 “服务 器 行为 "中 的 “重复 区 域 " 的 命令 , 单 击 type.php 
页 面 中 需要 重复 的 表格 ， 如 图 5-44 所 示 。 


J a +20% (102) ~ 
新 闻 标 题 : (Recorlsetlmewsl 洪 ww jnm 窑 目 
图 5-44 单 击 选择 要 重复 显示 的 一 行 
国 单 击 “ 应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 国 按 钮 ， 在 弹出 的 菜单 中 ， 选 
择 “ 重 复 区 域 ”的 选项 ,打开 “重复 区 域 ” 对话 框 ， 设 定 一 页 显示 的 数据 为 10 条 ， 如 图 5-45 
所 示 。 


图 5-45 选择 一 次 可 以 显示 的 次 数 


单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 
“重复 ”灰色 标签 ， 这 表示 已 经 完成 设置 。 
国 在 “插入 ” 栏 的 “数据 ”类 型 中 , 单 击 园 工 具 按钮 打开 “记录 集 导航 条 ”对 话 框 ， 
在 打开 的 对 话 框 中 选取 Recordset1 记 录 集 以 及 导航 条 的 显示 方式 ， 然 后 单 击 “ 确 定 ” 按 钮 
回 到 编辑 页 面 ， 会 发 现 页 面 中 出 现 了 该 记录 集 的 导航 条 ， 如 图 5$-46 所 示 。 
ee 
新 闻 标题 : {Recordsetl news_title} 详细 内 容 


67% GD) 


图 546 添加 “记录 集 导航 条 “ 
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国 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 国 工具 按钮 ， 在 弹出 的 菜单 中 ， 选 取 要 导 
航 状 态 的 记录 集 为 Recordset1， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 
记录 集 的 导航 状态 ， 如 图 5-47 所 示 。 


2 
图 5-47 添加 “记录 集 导航 状态 ” 
选取 文字 “详细 内 容 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 
文件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 newscontent.php， 设 置 
如 图 5-48 所 示 。 


尘 计 机 

Acer lo) 
| | 6 #9 D) 
一 Fe Ey 


rr 


文件 (NI: revwscontent php ~» [Me - 


图 548 选择 链接 文件 
单 击 “确定 ”按钮 ， 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 
newscontent.php?news_id=<?php echo $row_Recordsetl['news_id']; ?>。 将 参数 名 称 命名 为 
news_id， 如 图 5-49 所 示 。 


[<>iom] 格式 四 [无 了 类 无 " 

DE) ” 狼 放 D yw Recor: E 
9 =] 席 00)  20% 不 换行 ) 加 i = 
”| 高 如 | ”20 标题 名 站 


图 549 “参数 ”对 话 框 
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图 5-50 选择 要 显示 的 记录 


单 击 “应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 
选择 “显示 区 域 / 如 果 记 录 集 不 为 空 则 显示 区 域 ” 选项 ,打开 “如 果 记 录 集 不 为 空 则 显示 ” 
对 话 框 ， 在 “记录 集 ” 中 选择 Recordset1 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先 前 
所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 
经 完成 设置 ， 如 图 5-51 所 示 。 


国 cvampp\ntdocsnews\type php* -Ox 


TUS ners php 
\ 、 
Sr Start your intemet pusi 
o 


2 


sih ASADAL 


图 5-51 ”完成 设置 后 的 编辑 页 面 
输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没有 数 
据 时 要 显示 的 数据 表格 ， 如 图 5-52 所 示 。 


图 5-52 选择 没有 数据 时 显示 的 区 域 


单 击 “应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 
中 选择 “显示 区 域 /如 果 记 录 集 为 空 则 显示 区 域 ” 选 项 ， 在 “记录 集 ” 中 选择 Recordsetl 
再 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 
果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 效 果 如 图 5-53 所 示 。 
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画 cwamppwadocsnewstype hp -Ox 
Devs hp 


EE 


图 5-53 ”完成 设置 后 的 编辑 页 面 
_ 到 这 里 新 闻 分 类 页 面 type.php 的 设计 与 制作 就 已 经 完成 。 
553 ) 新 闻 内 容 页 面 设计 
新 闻 内 容 页 面 newscontent.php 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 
在 于 如 何 接 收 主页 面 index.php 和 type.php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页 面 的 页 面 设计 效果 如 图 5-54 所 示 。 


RN 71 Pm [i=l x 
拟人 行人 太 加 127.00.1 nm mi BEY 


PE Brep//27 00Unewsinews x 由 


5c PHP 新 闻 管理 系统 系统 首页 | 最 新 新 闻 上 新 闻 分 类 上 后 台 管 理 


Start your om As ADAL 


W 


新 间 标 是: 网 站 开通 了 加 入 时 间 : 2014.07-10 
着 有 内 寺 : 网 站 天 十 了 ， 农 迎 访问 


图 5-54 新 闻 内 容 页 面 设计 效果 图 
详细 操作 步骤 如 下 : 
执行 菜单 栏 “ 文 件 ” 一 “新 建 ” 命 令 创建 新 页 面 ， 执 行 菜单 栏 “ 文 件 ” 一 “保存 ” 
命令 ， 在 站 点 中 news 文 件 夹 中 将 该 文档 保存 为 ewscontent.php。 
新 闻 内 容 页 面 设 计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-55 所 示 。 
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cvampp\tdocsmewswmewscontentphp* i 
| as php 


Sr 两 


< ADAL 
Sy 和 2 sii 一 一 
4 


目 上 日 EE 


图 5-55 新闻 内 容 页 面 设计 效果 图 

单 击 “ 绑 定 ”面板 中 “增加 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 
集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 Recordset1 作 为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 news。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

@ 设置 “筛选 ”的 条 件 为 : news id =URL 参 数 /news_id。 

再 单 击 “ 确 定 ”按钮 后 就 完成 设 定 了 ， 如 图 $-56 所 示 。 


图 5-56 设 定 “ 记 录 集 ” 
绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 newscontent.php 页 面 中 的 适当 位 置 ， 这 样 
就 完成 了 新 闻 内 容 页 面 newscontent.php 的 设置 ， 如 图 5-57 所 示 。 
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He 


二 cwampp\ntdocs\news\newscontent php -Ox 
| SIRE ners php 


忆 PHP 新 闻 管 理 系 统 系统 首页 | 最 新 新 闻 | 新 闻 分 类 | 后 台 管 理 


Fe ~ sp 
\ Start your intemet bus vin ASADAL 本 


[3 howy CE 
图 5-57 绑 定 字段 


元 5.4 ”后 台 管理 页 面 


新 闻 管 理 系统 后 台 管理 对 于 网 站 很 重要 ， 管 理 者 可 以 由 这 个 后 台 增加 、 修 改 或 删除 新 
闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 系 统管 理 登录 入 口 页 面 的 


设计 效果 如 图 5-58 所 示 。 


所 |j 亿 | 对 | 儿 太 | 四 127.0.0.1 BEY 


图 5-58 系统 管理 入 口 页 面 

541 后 台 管 理 登 录 

后 台 管理 主页 面 必须 受到 权限 管理 ， 可 以 利用 登入 账号 与 密码 来 判别 是 否 由 此 用 户 来 
实现 权限 的 设置 管理 。 

详细 操作 步骤 如 下 : 

执行 菜单 栏 “文件 ” 一 “新 建 ” 命令， 创建 新 页 面 ， 输 入 网 页 标题 “管理 者 登录 ”， 
执行 菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文 件 夹 中 的 admin 文 件 夹 中 将 该 文档 保存 
为 admin_login.php。 

贺 执行 菜单 “插入 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

国 将 光标 放置 在 该 表单 中 ,执行 菜单 “插入 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 对 话 
框 ， 在 “ 行 数 ” 文 本 框 中 输入 需要 插入 表格 的 行 数 4。 在 “ 列 数 ” 文本 框 中 输入 需 要 插入 
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表格 的 列 数 2。 在 “表格 宽度 ”文本 框 中 输入 400 像 素 ， 其 他 的 选项 保持 默认 值 ， 如 图 5-59 
所 示 。 


图 5-59 插入 表格 


单 击 “确定 ”按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 “属性 ” 
面板 中 设置 “对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠 标 选中 第 1 行 表格 的 所 有 单元 格 ， 在 “ 属 
性 ”面板 中 单 击 加 按钮， 将 第 1 行 表格 合并 。 用 同样 的 方法 将 第 4 行 合并 。 

在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管理 中 心 ”， 在 表格 的 第 2 行 第 1 个 单元 
格 中 输入 文字 说 明 “ 用 户 : ”， 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ”按钮 回 ， 插 
入 单行 文本 域 表单 对 象 ， 定 义 文本 域名 为 username，“ 文 本 域 ”属性 设置 如 图 5-60 所 示 。 


属性 
国 文本 域 字符 宽度 tn) 2 ”| ”类 型 中 单行 6) ” 〇 多 行 I) 。 吕 密 码 P) 。 闫 | 无 > 
景 多 字符 数 | 】 初 她 值 C) [ ] 多 
口 禁 用 中 ) 
口 R 读 中) 


图 5-60 输入 “用 户 ” 名 和 插入 “文本 域 ”的 设置 
国 在 第 3 列表 格 中 , 输入 文字 说 明 “密码 : ”, 在 第 3 列表 格 的 第 2 个 单元 格 中 单 击 “ 文 
本 域 ”按钮 回 ， 插 入 单行 文本 域 ， 定义 文本 域名 为 password，“ 文 本 域 ”属性 设置 如 图 5-61 
所 示 。 
属性 


加 文本 域 字符 宽度 0 ， 类 型 〇 单行 6S) ” 〇 〇 多 行 中 灾 码 D) 类 四 | 无 ~ 
password 最 多 字符 数 初始 值 上) | 2 
口 禁 用 中 ) 
口 R 读 四 


图 5-61 输入 “密码 ”名 和 插入 “文本 域 ”的 设置 
单 击 选择 第 4 行 单元 格 ， 执 行 两 次 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 ， 插 入 
两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 
一 个 为 “ 重 设 表单 ”选项 ，“ 属 性 ”的 设置 如 图 $-62 所 示 。 
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名 "Se 
人 nm 
PE 按钮 名 称 值 名 辟 录 动作 回 提交 表单 GE) ” 〇 无 四 类 @) 无 加 
Subvitl | 口 重 设 表单 四 ) 
属性 
| 各部 值 o 至 村 动作 〇 提交 表单 8) 〇 无 0D 类 ,无 二 
Subnit2 中 重 设 表单 @) 


图 5-62 设置 按钮 名 称 的 属性 
国 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 图 按钮 ， 在 弹出 的 菜单 中 选 
择 “ 用 户 身份 验证 /登录 用 户 ” 选 项 ， 打 开 “ 登 录用 户 ” 对 话 框 , 设置 如 果 不 成 功 将 返回 主 
页 面 index.php， 如 果 成 功 将 登录 后 台 管 理 主页 面 4dmin.php， 如 图 5-63 所 示 。 


从 表单 获取 输入 :forn1 "] 亡 枉 
用 户 名字 隘 : [eaeraeas = a 
[psswerd = ee 
NE 
| 
| 
密码 列 [password 了 
如 果 登 录 成 功 ， 转 到 -admin php BE 
四 转 到 前 一 个 URLG0 果 世 存 在 ) 
如 果 登 录 失 败 ， 转 到 /index php BE 
基于 以 下 项 限制 访问 : 加 用 户 名 和 密码 
用 户 名 、 密码 和 访问 级 别 
款 了 级 别 自 :4 


图 5-63 登录 用 户 的 设 定 
国 执行 菜单 栏 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ”面板 中 
的 团 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 
username 和 password 文 本 域 的 “ 值 ” 都 为 “必需 的 ”、“ 可 接受 ”为 “任何 东西 ”， 如 图 


5-64 所 示 。 
Ee 
rT] 
本 | 
| 
值 : 团 比 者 的 
可 接受 ， 回 任何 东西 数字 


图 564 “检查 表单 ”对 话 框 
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单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin_login.php 的 设 
计 与 制作 。 


< 次 5.4.2 ) 后 台 管理 主页 面 
后 台 管理 主页 面 是 管理 者 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 增 、 
修改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 结构 如 


图 5-65 所 示 。 
. 
> > Ns 
Start your intemmet business 
"ASADAL 


\ Cs 


新 闻 后 台 管理 中 心 : 


re ele EE" 
KK vy ol a We a We a 目 日 呢 770x 402v 


图 5-65 后 台 管 理 主页 面 效 果 图 
详细 操作 步骤 如 下 : 
打开 admin.php 页 面 ，( 此 页 面 设计 比较 简单 ,页 面 设计 在 此 不 做 说 明 ) ， 单 击 “ 绑 
定 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 中 选择 “记录 集 (查询 ) ”选项 ， 在 “记录 集 ” 对 话 
框 中 进行 如 下 设置 : 
在 “名 称 ” 文本 框 中 输入 Re 作为 该 记录 集 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 news。 
@ 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 
@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
@ “排序 ”设置 为 news_id 降 序 方式 。 
完成 的 设置 情况 如 图 5-66 所 示 。 
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VBL 允 数 


排序 : |news_id | 世 四 


图 5-66 设 定 “ 记 录 集 ” 
绑 定 记录 集 后 ， 将 Re 记录 集中 的 news_title 字 段 插入 至 admin.php 网 页 中 的 适当 位 
置 ， 如 图 5-67 所 示 。 


D Cyampp\htdocs\news\admin\admin php” 


图 5-67 记录 集 的 字段 插入 至 admin.php 网 页 中 
加 由 于 要 加 入 “重复 区 域 ”命令 ， 所 以 首先 选择 需要 重复 的 表格 ， 如 图 5-68 所 示 。 


| 味 题 : {Re. news_title} 


图 5-68 选择 重复 的 区 域 


单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 
A “重复 区 域 ” 选 项 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 记 
录 ， 如 图 5-69 所 示 。 
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图 5-69 设置 记录 集 显 示 的 条 数 
国 单 击 “确定 ”按钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设 定 了 。 
四 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 辆 工具 按钮 打开 “记录 集 导 航 条 ”对 话 框 ， 
选取 Re 记录 集 的 显示 方式 为 “文本 ”， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 
出 现 该 记录 集 的 导航 条 ， 如 图 5$-70 所 示 。 


示 cvamppwtdocsmewsvadminvadmin php* 


图 5-70 页面 显示 效果 


admin.php 是 提供 管理 者 链接 至 新 闻 编 辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 ， 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 5-6 所 示 。 


表 5-6 admin.php 页 面 的 连接 设置 


名 称 连接 页 面 
添加 新 闻 news_add.php 
修改 news_upd.php 
删除 news_del.php 


其 中 “标题 字段 {re_news_title}”、“ 修 改 ” 及 “删除 ”的 链接 必须 要 传递 参数 给 转 到 的 页 面 ， 
这 样 转 到 的 页 面 才能 够 根据 参数 值 而 从 数据 库 将 某 一 笔 数 据 筛选 出 来 再 进行 编辑 。 
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国 首先 选取 “添加 新 闻 ”, 在 “属性 ”面板 中 将 它 链接 到 admin 文 件 夹 中 的 news_add.php 
页 面 。 

国 选取 右边 栏 中 的 “修改 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 news_upd.php， 
如 图 5-71 所 示 。 


图 5-71 选择 链接 文件 
单 击 “ 参 数 ” 按 钮 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 
news_upd.php?news_id=<?php echo $row_Re['news_id']; ?>， 如 图 5-72 所 示 。 


格式 中) [无 站 类 无 温 摇 尘 冯 标题 m) 
~ 树 撞 0) Tv 了 -昌国 。 上 村 名 


吕 三 | 单元 格 。 水 平 乙 )[ 默 认 | 宽 0) 30x 不 换行 o) 门 ”背景 颜色 (c) 厂 -| 
一 FE 标题 @) 站 


图 5-72 “动态 数据 ”对 话 框 
选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news_del.php， 并 传递 新 
闻 标 题 的 ID 参数 news_del.php?news_id=<?php echo $row_Re[mews id]; ?>， 如 图 5-73 所 示 。 


图 5-73 设置 传递 至 news_del.php 
选取 标题 字段 {Re_news_title} 并 重复 上 面 的 操作 ,要 前 往 页 面 改 为 newscontent.php 
并 传递 新 闻 参 数 ../newscontent.php?news_id=<?php echo Srow_Re['news id']; ?>， 如 图 5-74 
所 示 。 
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EE 入 小 日 由 


BmmSeverscripts 2014/12/8 1613 
下 noes 2014/12/8 1042 
drin 2014]12/8 1633 
BB Comnecions 2014/12/8 1042 


Bdats 2014/12/8 104: 
下 mesos 2014/12/8 1350 交 
目 auap 20L1/81820 。 php 六 和 oke 
| newscontent php 201I/3 800 PHP 文 昨 34 加 | 
Bypephep 20LV7/9 7:53 PHP 文件 BK 


图 5-74 ”设置 传递 至 newscontent.php 

单 击 “ 确 定 ”按钮 ， 完 成 转 到 详细 页 面 的 设置 ， 到 这 里 已 经 完成 了 新 闻 内 容 的 编 
辑 ， 现 在 来 设置 一 下 新 闻 分 类 ， 单 击 “ 绑 定 ” 面 板 上 的 团 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 
“记录 集 (查询 ) ”选项 ， 在 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 Rel 作 为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-75 所 示 。 


图 5.75 设置 “记录 集 ” 对话 
绑 定 记录 集 后 , 请 将 Rel 记 录 集 中 的 type_name 字 段 插入 至 admin.php 网 页 中 的 适当 
位 置 ， 如 图 5-76 所 示 。 
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图 5-76 插入 字段 至 admin.php 网 页 中 
加 入 “服务 器 行为 ”中 “重复 区 域 ”命令 ， 选 择 需 要 重复 的 表格 ， 如 图 5-77 所 示 。 
{Rel. type_nane}】 [修改 ] [删除 ] 
图 5-77 ”选择 要 重复 的 一 列 
单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按 钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选项， 打开 “重复 区 域 ”对 话 框 ， 设 定 一 页 显示 的 数据 为 “所 有 
记录 ”， 如 图 5-78 所 示 。 


图 5-78 设置 “重复 区 域 ” 对 话 框 
单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 的 区 域 左 上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
首先 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文 件 夹 中 的 type_upd.php 链 接 并 传 
递 type_id 参 数 type_upd.php?type_id=<?php echo Srow_Rel['type_id']; ?>， 如 图 5-79 所 示 。 
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加 
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5-79 ”设置 传递 至 type_upd.php 


选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del.php 并 传递 
type_id 参 数 type_del.php?type_id=<?php echo Srow_Rel['type_id']; ?>， 如 图 5-80 所 示 。 


[国运 3 六 作 
> HAM Acer (C) » xampp » hadoce ，news » admin » 9 EZ 站 
组 加 ” 。 新 于 文件 夫 "He 
型 55R 的 8 本 “各 和 LE a 大 小 
和 netes 2014/12J8 1042 。 六 4 夫 
周记 admin.php 2014/12/8 1633 。 pHp 文 御 Er 
Cbd admin cginpnp 5 
回国 # 目 wew addphp Ta 
Dx i sx 
国志 BB newsupdphp SxB 
由 已 wpe eddphp 2011716 1605 PHP 文件 sxe 
| pedelphp 20117110 1218 PHP 文件 Er 
所 Cypespaphp 200M7n0 1210 。 php 了 4 
人 Acer (cy 
三 ID:) 
2 太 坟 和 E) ~ 
ES 2 
KHEINY ype delphp ET 到 
Leens EE 


图 5-80 设置 传递 至 type_del.php 
再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文 件 夹 中 的 
type_add.php 页 面 。 
后 台 管 理 是 管理 员 在 后 台 管 理 入 口 页 面 4dmin login.php 输 入 正确 的 账号 和 密码 才 
可 以 进入 的 一 个 页 面 ， 所 以 必须 设置 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ”面板 群 组 
中 “服务 器 行为 ”标签 中 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “用 户 身份 验证 /限制 对 页 
的 访问 ”选项 ， 如 图 5-81 所 示 。 
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图 5-81 选择 “限制 对 页 的 访问 ”命令 
在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 的 “基于 以 下 内 容 进行 限制 ”选择 “用 户 
名 和 密码 ”， 如 果 访问 被 拒绝 ， 则 转 到 首页 index.php， 如 图 5-82 所 示 。 


基于 以 下 内 容 进行 限制 : 回 用户 吉 和 区 码 


如 果 访 问 被 拒绝 ，m 到 : /index_ php 


图 5-82 “限制 对 页 的 访问 ”对 话 框 
单 击 “ 确 定 ”按钮 ， 就 完成 了 后 台 管 理 主页 面 admin.php 的 制作 。 


< 543 ) 新 增 新 闻 页 面 


新 增 新 闻 页 面 news_add.php， 设 计 的 页 面 效 果 如 图 5-83 所 示 ， 实 现 了 插入 新 闻 的 功能 。 


翅 cwamppwtdocsmewsadminwmews add php” -Ox 
ors Hhp 7 
:Hehogia: : 
; 断 
: 国 
lL 
NN 
-加 
EE [TESES 


图 5-83 新 增 新 闻 页 面 设计 
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os 
详细 操作 步骤 如 下 : 


创建 news_add.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 了 图 按钮 ， 在 弹出 的 下 拉 菜 单 中 
选择 “记录 集 (查询 ) ”选项 ， 打 开 的 “记录 集 ” 对 话 框 如 图 5-84 所 示 。 


记录 条 [x= 
fh: RecordsetT 
连接 [eons [Fa 
一 Eo 
表格 - [nenstype 四 
人 
[23E3 加 
VRL 才 数 ] 
排序 :无 下 [升序 


图 5-84 “记录 集 ” 对 话 框 
贺 绑 定 记录 集 后 ， 单 击 “新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 属性 


面板 中 单 击 区 过 _] 控 钮 ， 在 打开 的 “动态 列表 /菜单 ”中 进行 设置 ， 如 图 5-85 所 示 。 
动态 列表 / 职 单 is 
菜单 "news_type” 在 表单 “fornl 
| | 
men 到 到 DB | Em 
值 标签 
来 自 记录 集 的 法 所 [Eeesrdat | 
值 :ltymeid 了 
标 葵 [epeome。 | 
选取 值 等 于 《3php $row_Recordset1["type- 加 
用 


图 5-85 “动态 列表 /菜单 ”对 话 框 

加 本 章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实 现 自动 获取 系统 的 默认 时 间 ， 当 插入 新 
闻 时 能 自动 生成 当时 的 时 间 。 方 法 是 绑 定 一 个 隐藏 字段 并 命名 为 news_date， 切 换 到 代码 行 
将 值 设置 如 下 ， 单 击 “确定 ”按钮 。 

<input name="news_date" type="hidden" id="news_date" value="<?php 

date default timezone set('Asia/Shanghai'); 

echo date("Y-m-d"); 

了 > 


// 设 置 时 间 格式 和 时 间 区 域 
在 news_add.php 编 辑 页 面 ， 再 次 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 标 
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签 上 的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “插入 记录 ”选项 ， 如 图 $-86 所 示 。 


Te me. 国 @L=IeLz] 
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-om 


图 5-86 ”选择 “插入 记录 ”选项 
设置 “插入 记录 ”对 话 框 ， 如 图 5-87 所 示 。 


图 5-87 “插入 记录 ”对 话 框 设置 
执行 菜单 栏 “ 窗 口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ”面板 上 
的 固 按 钮 ， 在 打开 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 打 开 “ 检 查 表 单 ”对 话 框 ， 所 有 
域 均 设置 值 为 “必需 的 ”、“ 可 接受 ”为 “任何 东西 ”， 如 图 5-88 所 示 。 


图 5-88 “检查 表单 ”对 话 框 设 置 
单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 就 完成 news_add.php 页 面 的 设计 了 。 
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-544 ) 修 改 新 闻 页 面 


修改 新 闻 页 面 news_upd.php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 
改 ， 修 改 数据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-89 所 示 。 


[本 新 ] | 重 轩 
w+ S08 (5 


KI Voy ‘for #fon! Wble WW Wd pm sm [TEST 


图 5-89 修改 新 闻 页 面 设计 


详细 操作 步 又 如 下 : 


园 打开 news_upd.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 
“记录 集 (查询 ) ”选项 ， 打 开 的 “记录 集 ” 对 话 框 ， 在 对 话 框 中 的 设 定 如 图 5-90 所 示 。 


名 称 : Recordset1 


图 5-90 “记录 集 ” 对 话 框 设置 
用 同样 方法 再 绑 定 一 个 记录 集 Recordse2P2， 在 对 话 框 中 的 设 定 如 图 5-91 所 示 。 
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名 称 : Recordset2 

连 护 [ee [Fa 

表格 : newstype =- 
列 图 全 部 刁 选 定 的 : 


证 迁 : 欧 可 = 


排序 :无 到 [升序 


图 5-91 “记录 集 ” 对 话 框 设置 
绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 news_upd.php 网 页 中 的 适当 位 置 , 如 图 5-92 

所 示 。 其 中 加 入 一 个 隐藏 字段 绑 定 news_id。 
vamp ssi pa pe | 
| 
有 好 ! 法办: fF 


Tr 
i 
Ms TE ecorasati 


ecordsat I. news_content] 


ee 


ol = 十 国 


I» MS 可 到 Dr ED (TEEPE 
图 5-92 字段 的 插入 

在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 和 上 面 加 隐藏 字段 取得 时 
间 的 方法 一 样 ， 直 接 在 字段 的 值 输 入 取得 系统 时 间 的 代码 ， 如 图 5-93 所 示 。 


<input name="news_date" type="text" id="news_date" value="<?php 
date _ default timezone set('Asia/Shanghai'); 
echo date("Y-m-d"); 


2 
同上 一 一 一 一 一- 一- 三 
画 一 字符 宽度 wj [30 | 类 型 @O) 单 行 B) 。” 〇 多 行 D 。 〇 〇 穴 码 @) 类 四 | 无 
Inews_date 最 多 字符 数 | 初始 入) |<?phpaate_default_timezone_setCA| 多 
禁用 O) 
只 读 中 ) 


图 5-93 ”加 入 代码 取得 最 新 时 间 


加 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 新 闻 分 类 的 列表 菜单 属性 面板 中 单 击 E ae 
按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 设置 ， 如 图 5-94 所 示 。 
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图 5-94 “动态 列表 /菜单 "对 话 框 
四 完成 表单 的 设置 后 ， 要 在 news_upd.php 页 面 加 入 “服务 器 行为 ”中 “更 新 记录 ” 
的 设 定 ， 在 news_upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 
的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ”选项 ， 如 图 5-95 所 示 。 


图 5-95 加 入 “更 新 记录 ”命令 
贺 在 打开 的 “更 新 记录 ”对 话 框 中 进行 设置 ， 如 图 5-96 所 示 。 其 中 news_id 设 置 为 主键 。 
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_ 国 单 击 “ 确 定 ” 按 钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 
多 5.4.5 ) 删 除 新 闻 页 面 


删除 新 闻 页 面 news_delphp 和 修改 的 页 面 差不多 , 如 图 5-97 所 示 。 其 方法 是 将 表单 中 的 
数据 从 站 点 的 数据 表 中 删除 。 


示 cvampp\ntdocs\news\admin\news_del php* 加 
RE ners. php 

:新 司 标题: - 
| 类， 


a bE 


» 


f St 国 
RSTILEI [TI 日 日 国 slxstv 


图 5-97 删除 新 闻 页 面 的 设计 


详细 操作 步骤 如 下 : 


打开 news_del.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 固 按 钮 ， 接 着 在 弹出 的 下 拉 菜 单 
中 选择 “记录 集 (查询 ) ”选项 ， 设 置 打 开 的 “记录 集 ” 对 话 框 ， 如 图 $-98 所 示 。 


LE 一 
名 称 : Recordset1 
连接: [ees 9 [Fa 
a CC 
= 
国 


图 5-98 “记录 集 ” 对 话 框 
用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 如 图 5-99 所 示 。 
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图 5-99 “记录 集 ” 对 话 框 
绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 news_del.php 网 页 中 的 适当 位 置 ,其 中 绑 定 
隐藏 字段 为 news_id， 如 图 5-100 所 示 。 


(Recordset 1. news_content} 


上 


[县 清 | 


7 


bedy fw. Whe a 本 本 [ew DD 
图 5-100 字段 的 插入 


绑 定 记录 集 后 ， 单 击 “ 新 闻 分 类 ”的 菜单 ， 在 新 闻 分 类 的 菜单 属性 面板 中 单 击 
区 一 静 下 按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 设置 ， 如 图 5-101 所 示 .。 


选取 值 等 于 : 《?php $row_Recordset2['type_ 一 


图 5-101 绑 定 “ 动 态 列表 /菜单 
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辆 完成 表单 的 布置 后 ， 要 在 news_del.php 页 面 加 入 “服务 器 行为 ”中 “删除 记录 ”的 
设置 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 图 按钮 ， 在 弹出 的 下 拉 菜 单 中 
选择 “删除 记录 ”选项 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 输 入 设 定 值 如 图 5-102 所 示 。 


主键 列 - aews-ia 回 
主键 值 -LURL 参数 了 


肌 除 后 ， 转 到 -adninphp 


图 5-102 “删除 记录 ”对 话 框 
_ 国 单 南 “确定 ”按钮 ， 完 成 删除 新 闻 页 面 的 设计 。 
< 546 ) 新 增 新 闻 分 类 页 面 


新 增 新 闻 分 类 页 面 type_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 newstype 数 据 表 中 ， 
页 面 设计 如 图 5-103 所 示 。 


WI Wi i tos! NY A [Dn 上 i 


图 5-103 新 增 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 : 


单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”标签 中 国 按钮 ， 在 弹出 的 下 拉 菜 单 
人 “插入 记录 ”选项 ， 在 打开 的 “插入 记录 ”对 话 框 中 输入 设 定 值 ， 如 图 5-104 所 示 。 


图 5-104 设 定 “ 插 入 记录 ” 
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TO 先 
® 


选择 表单 ， 执 行 菜单 栏 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 打 开 “ 检 查 表单 ”对 
话 框 ， 设 置 “ 值 ”为 “必需 的 ”、“ 可 接受 ”为 “任何 东西 ”， 如 图 5-105 所 示 。 


图 5-105 设置 “检查 表单 ”对 话 框 
园 单 击 “ 确 定 ” 按 钮 ， 完 成 type_add.php 页 面 设计 。 


-人 547 ) 修 改 新 闻 分 类 页 面 


修改 新 闻 分 类 页 面 type_upd.php 的 功能 是 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修 
改 ， 修 改 数据 后 再 更 新 至 数据 表 中 ， 页 面 设计 如 图 5-106 所 示 。 


9 人: 转 
EE 
E20 D0:itiv 


图 5-106 修改 新 闻 分 类 页 面 设计 
详细 操作 步骤 如 下 : 
打开 type_upd.php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 的 团 按 钮 。 接 
着 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 打 开 “ 记 录 集 ”对 话 框 ， 在 打开 的 
“记录 集 ” 对 话 框 中 输入 设 定 值 ， 如 图 5-107 所 示 。 


| fr: Recordset1 
连接- [eers 
表格 [aevztype 

上 加 主 部 | 日 这 定 的 : 


FE 
type_nane 


a l 
WRL 孝 才 ei 
| 


图 5-107 “记录 集 ” 对 话 框 
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绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 type_upd.php 网 页 中 的 适当 位 置 , 如 图 5-108 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id. 


二 cvamppintdocs\news\admin\type_upd php* -ox 


| ners shy 司 


] | 
| EE 二 | | 


E> Moy fom te HA Be rm mv | 
图 5-108 字段 的 插入 
完成 表单 的 布置 后 ， 要 在 type_upd.php 页 面 加 入 “服务 器 行为 ”中 “更 新 记录 ”的 
设 定 ， 在 type_upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 的 畴 按 
钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “更 新 记录 ”选项 ， 在 打开 的 “更 新 记录 ”对 话 框 中 输入 设 
定 值 ， 如 图 5-109 所 示 。 


在 更 新 后 转 到 : adnin. es 


图 5-109 “更 新 记录 ”对 话 框 
园 单 击 “ 确 定 ” 按 钮 ， 完 成 修改 新 闻 分 类 页 面 的 设计 。 
-入 548) 删除 新 闻 分 类 页 面 


删除 新 闻 分 类 页 面 type_del.php 的 功能 ， 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 
删除 。 详 细 操作 步骤 如 下 : 

打开 type_del.php 页 面 ， 该 页 面 和 更 新 的 页 面 是 一 模 一 样 的 。 单 击 “ 应 用 程序 ” 面 
板 中 “ 绑 定 ”标签 的 图 按 钮 。 接着 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 打 
开 “ 记 录 集 ”对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 输入 设 定 值 ， 如 图 5-110 所 示 。 
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第 5 章 全 程 实例 三 : 新 闻 管 理 系统 -@ 
ats ! 


名 称 : Recordset1 
连接 : |nens 
表格 -| newstype 


列 回 全 部 ”日 选 定 的 : 


type_id 
type_nane 


图 5-110 “记录 集 ” 对 话 框 
绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 type_del.php 网 页 中 的 适当 位 置 ， 如 图 5-111 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 


[Recordsotil,type nme] 豆 
[重要 


ED Voayy fo sforn! Noble fr a CDemeis 日 日 呢 6%x i191 
图 5-111 字段 的 插入 
完成 表单 的 布置 后 ， 要 在 type_del.php 页 面 加 入 “服务 器 行为 ”中 “删除 记录 ”的 
设 定 ， 在 type_del.php 的 页 面 上 , 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 的 团 按钮 ， 
在 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ”选项 ， 在 打开 的 “删除 记录 ”对 话 框 中 输入 设 定 值 ， 
如 图 5-112 所 示 。 


图 5-112 “删除 记录 ”对 话 框 


一 个 实用 的 新 闻 管 理 系 统 就 此 开发 完毕 ， 读 者 可 以 将 本 章 开 发 的 新 闻 管 理 系 统 的 方法 
应 用 到 实际 的 大 型 网 站 建设 中 去 。 
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第 章 


全 程 实例 四 : 在 绪 投 票 管理 系统 


网 站 的 投票 管理 系统 设置 好 投票 主题 之 后 ， 网 站 的 会 员 积 极 参与 可 以 起 到 活跃 会 员 ， 
增加 浏览 量 的 作用 。 一 个 投票 管理 系统 可 分 为 3 个 主要 的 功能 模块 : 投票 功能 、 投 票 处理 
功能 以 及 显示 投票 结果 功能 。 投 票 管理 系统 首先 给 出 投票 选 题 ( 即 供 投票 者 选择 的 表单 对 
象 ) ， 当 投票 者 单 击 选择 投票 按钮 后 ， 投 票 处 理 功 能 激活 ， 对 服务 器 传送 过 来 的 数据 做 出 
相应 的 处 理 , 先 判断 用 户 选择 的 是 哪 一 项 , 昧 计 相 应 项 的 字段 值 ,然后 对 数据 库 进 行 更 新 ， 
最 后 将 投票 的 结果 显示 出 来 。 


投票 管理 系统 站 点 的 设计 
投票 管理 系统 数据 库 的 规划 
计算 投票 的 方法 

防止 刷新 的 设置 


1 6.1 ”在 线 投票 管理 系统 规划 

在 线 投票 管理 系统 在 设计 开发 之 前 , 对 将 要 开发 的 功能 进行 一 下 整体 的 规划 。 本 实例 可 以 
分 为 3 个 部 分 的 页 面 内 容 , 一 是 计算 投票 页 面 , 二 是 显示 投票 结果 页 面 , 三 是 用 来 提供 选择 的 
页 面 。 
< 577) 页 面 规划 设计 

根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 
制作 的 投票 管理 系统 的 文件 夹 和 文件 如 图 6-1 所 示 。 


Eee 
Oh Hn » acer( » xampp » htdocs » vote » -|4‖ Ra vo P| 

文件 (” 编 纺 (E) 查看 V) 工具 (1 帮助 (H) 
组 如 ” 。 周 打 开 > 。 齐 明 。 新 建文 件 交 二 ~- © 

国 视 顷 “ 证 大 小 

国 时; B _mmServerScripts 

文生 notes 

加 地 镍 下 吉 上 Connections 

由 音乐 用 date 

上 images 

顺 计算 机 Bmdb 

岛 Acer (C) sory.php 1KB 

地 (DD) 可 日 votephp ds 

A (E) Dvoteadd.php 52 2KB 

Lvoteokphp 2014/12/8 18:55 PHP 文件 5 KB 

铬 赂 

师 DouGLAS-PC 

nr ont4tnanc 工 

voteok.php 修改 日 财 ; 2014/12/8 18:55 创建 日 期 : 2014/12/8 18:47 
PHP 文 ! 大 小 4.10 KB 
图 6-1 站 点 规划 文件 
本 实例 制作 的 投票 系统 总 共有 4 个 页 面 ， 页 面 的 功能 与 文件 名 称 如 表 6-1 所 示 。 


表 6-1 在线 投 票 系统 网 页 设计 表 


投票 失败 页 面 


< 次 6.1.2 ) 系 统 页 面 设计 

投票 管理 系统 的 页 面 共 4 个 ， 包 括 开始 投票 页 面 、 计 算 投 票 页 面 、 显 示 投 票 结果 页 面 
以 及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd.php 的 实现 方法 是 : 接收 vote.php 所 传递 过 来 的 
参数 然后 执行 累加 的 功能 ， 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 惟一 性 设置 了 防 
止 页 面 刷新 的 功能 。 开 始 投票 页 面 和 显示 投票 结果 页 面 的 设计 如 图 6-2 和 6-3 所 示 。 
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EE a 
€ 15| A |main| 


EE PE 


€|)) 人 A) 友 | 团 | httpW12700Uvoreyvoteokphp 


苛 


[1 

了 [EE 
三 党 [E27 
= 133% 败 守 : 醒 半 


CT 三 dtwe om zu in rights rosevet 量化 折 


图 6-2 投票 和 天 统 上 页 图 6-3 投票 结果 显示 页 面 
九 6.2 ”系统 数据 库 的 设计 


本 实例 主要 掌握 投票 管理 系统 数据 库 的 连接 方法 ， 投 票 管理 系统 的 数据 库 主 要 用 来 存 
-527 数据 库 设计 
投票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 人 P 


地 址 的 数据 表 ip。 
制作 的 步骤 如 下 : 


在 phpmyAdmin 中 建立 数据 库 vote， 选 择 国 数据 库 命令 打开 本 地 的 “数据 库 ” 管 理 页 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 vote， 单 击 打开 后 面 的 数据 库 类 型 下 拉 
菜单 ， 选 择 utf8_general_ci 选 项 ， 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ”页 面 ， 在 数据 库 列 
表 中 就 已 经 建立 了 vote 的 数据 库 ， 如 图 6-4 所 示 。 


EE 35082 71 < ml- Xx 
所 上 | 硝 上 | 会 上 六 中 包 httpy/127.0.0.1phpmyadmin/#PMAURL-C 


phpMyAdmin 
全 Oe 


日 间 据 库 加 SQL 启 拓 和 用 户 区 Sx 司 SA v 鲁 多 


但 过 使 有 的 表 ) 百 
3 cdcol 

3 infomaton_schama “服务器 .1270.0.1 via TCPAP 
3 member 地 和 六 交手 MySQL 

a myeq 


phpweb 
tect | ex-chmese smpifed 
Fe 二 
日 时 主 归 | pmahomme 四 | 
“ 字 azx 加 | 


i -Apache 47 (Win32) 


OpanSSU10 1e PHP/S ES 
* 并 据 话 全 六 湛 疡 本 ibmysql -| 
mysqnd50 1Tdev- -| 


图 6-4 开始 建立 数据 库 
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单 击 左边 的 vote 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 


名 ip 和 vote ( 即 创建 2 个 数据 表 ) 。 创 建 ip 数据 表 (字段 结构 见 表 6-2 ) ， 用 于 限制 重复 投票 


分 别 输入 数据 表 


使 用 ， 输 入 数据 域名 以 及 设置 数据 类 型 的 相关 数据 ， 如 图 6-5 所 示 。 


字段 名 称 
主题 编号 


表 6-2 
数据 类 型 


ip 数 据 表 


字段 大 小 
长 整 型 


投票 的 ip 地 址 


EE 


专 马帮 让 图 上 


phpMyAdmin 


© 
区 


EE 
[EEC 


deal 
lormation schema 

本 member 
mq 


二 porformance_sehoms 
phpmyacmn, 


INTEGER 
VARCHAR 


有 a Pry FT 


127001 


ET] 


255 


ow 


b= = = [I 


1 


好 Sa 而 SA P 和 人 


各: 


吉本 人 is 可。 六 FRI 。。 大 小 和 全 
Ne EE 
癌 wm 3 二 必 革 用 司 有 > 电 M WiSM vonLd 

2 可 者 名 让 ooa omana 4 3 
人 e135 [295 国 | 
FETT 

EL 


图 6-5 创建 的 ip 数据 表 
设计 vote 数据 表 用 于 储存 投票 的 选项 和 投票 的 数量 ， 输 入 数据 域名 以 及 设置 数据 
域 位 的 相关 数据 ， 如 图 6-6 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 vote 的 字段 
结构 如 表 6-3 所 示 。 
表 6-3 ”投票 数据 表 vote 
段 名 称 数据 类 型 


ET | 
| HB 更 |iem vcHtAR | | 是 | 


字段 大 小 必 填 字段 


EE 1 = 
所 | 妃 | 青 | 友 | 轩 hrtpVW12700UPh REY 


让 127004/127001/vwoie x 


phpMyAdmin | 
全 B90 己基 Xs 月 sa 2 BM 和 A 加 S% 王 sA af ras || 
二话 1 -| 5 名 天 排尿 织 则 医 空转 本 外 入 作 
后 这 休 用 的 克 ) ] 和 时 三 村 
日 1 mm) 百 二 AUTO_NCRENEN 2 Ww © Ws 斧 | 
ES 
2 Mem varchar(s0) ua general 5 = 召开 2 us 2 】 
3 vete ma 要 至 En OMe Eu 
日 zz 目 液 人 日 轩 : 力主 而 只 -下 实 引 


卫 空 间 国 全 文系 


让 Se。 人 (第 2 版 ) 


Se 


为 了 方便 后 面 系统 开发 的 需要 , 事先 在 Vote 数 据 表 里 加 入 4 个 投票 的 数据 , 单 击 “ 浏 
览 ” Rs 在 数据 天 手动 加 入 名 为 选项 -选项 4 中 个 选择 模式 ， 如 图 6-7 所 示 。 


图 6-7 输入 投票 选择 
数据 库 创建 完毕 ， 可 以 发 现在 线 投票 管理 系统 的 数据 库 相 对 比较 简单 。 


< 从 822) 投票 管理 系统 站 点 


在 Dreamweaver CC 中 创建 一 个 “投票 系统 ”网 站 站 点 vote， 由 于 这 是 PHP 数 据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 6-4 所 示 。 


表 6-4 ”在 线 投票 管理 系统 站 点 基本 参数 


vote 


创建 vote 站 点 具体 操作 步骤 如 下 : 


加 首先 在 Cixampp\htdocs 路 径 下 建立 vote 文 件 夹 ( 如 图 6-8 所 示 ) ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 底下 。 


站 点 名 称 
本 机 根 目录 
测试 服务 器 
网 站 测试 地 址 

MySQL 服 务 器 地 址 
管理 账号 / 密码 


图 6-8 建立 站 点 文件 夹 vote 
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运行 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打开 “ 管 
理 站 点 ”对 话 框 ， 如 图 6-9 所 示 。 


[ET EE (Re ] 
Cw | 


图 6-9 “管理 站 点 ”对 话 框 
园 对 话 框 的 上 面 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 角 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 vote” 对 话 框 ， 进 行 如 图 6-10 所 示 的 参数 设置 。 


Dreamweaver 站 点 是 | 网 站 中信 用 的 所 高 证 作 和 插 间 的 和合 Te 


ED 


总 设 四 


和 以 存 此 处 为 Dieamwever 让 三 渴 往 本 直 六 隆庆 和 名 入 


图 6-10 建立 vote 站 点 


单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ]， 打 开 “基本” 
选项 卡 进行 如 图 6-11 所 示 的 参数 设置 。 


和 
EEC 一 到 一) a 
isa ee | 
这 北方 法 : | 二 起 有 FE 由 到 
Eee 
四 [mpyiizroowml |] | 
人 了 向 
Ba] 人 BH 


图 6-11 “基本 ”选项 卡 设置 
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pe Sl 网 站 开 入 全 程 实例 (第? 上) 


加 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL (表示 是 使 用 PHP 开 发 
的 网 页 ) ， 其 他 的 保持 默认 值 ， 如 图 6-12 所 示 。 


加 给 P 忆 信息 
口 保存 时 自动 将 文 六 上 传 到 那 务 器 
口 让 文人 出 9 能 

可 打 文 牢 之 前 和 出 


图 6-12 设置 “高 级 ”选项 卡 
国 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 


“测试 ” 复 选 框 ， 如 图 6-13 
所 示 。 


您 将 在 此 位 置 选 择 承 核 Web 上 的 页 面 的 服务 器 。 此 于 话 杠 的 设置 未 自 | 
lntornet 撒 务 提供 商 (15P) 或 Web 宕 理 只 


et i wd 


FE] | 


图 6-13 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 
刚才 所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CC 测试 在 线 投 票 系统 网 页 的 网 站 环境 设置 。 


-入 623 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 
的 连接 设置 如 下 : 


将 光盘 中 设计 的 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ,打开 vote.php 投 票 首页 ， 如 图 
6-14 所 示 。 
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动 cyamppntdocs\voteWwore php* 下 
REY vote she 了 


图 6-14 打开 网 站 首页 
单 击 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命令， 打开 “数据 库 ” 面 板 。 在 “数据 库 ” 
面板 中 单 击 选择 “+” 图标 ， 并 在 打开 的 下 拉 菜 单 中 选择 ”MySQL 连接 ”选项 ， 如 图 6-15 
所 示 。 


图 6-15 选择 MySQL 连接 
在 “MySQL 连接 ”对 话 框 中 输入 “连接 名 称 ”为 vote， “MySQL 服 务 器 ”名 为 
localhost， “用 户 名 ”为 root， 密 码 为 admin。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 
“选取 ”按钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 。 选择 刚 建立 的 范例 数据 库 vote， 具 体 的 
设置 内 容 如 图 6-16 所 示 。 


MySQL 连接 


连接 名 称 : vote 
MySQL 服务 器 : localhost 
用 户 名 : root 
密码 : 
数据 库 : vote 


图 6-16 设置 MySQL 连接 参数 
单 击 “ 测 试 ” 按 钮 测试 与 MySQL 数 据 库 的 连接 是 否 正 确 ， 如 果 正 确 就 出 现 一 个 提 
示 消 息 框 (如 图 6-17 所 示 ) ， 这 表示 数据 库 连 接 设置 成 功 了 。 
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图 6-17 设置 成 功 
加 单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ”面板 中 则 显示 绑 定 过 来 的 数 


据 库 ， 如 图 6-18 所 示 。 


vote 
本 了 Ga 的 
iten (varcher 50 必需 的 ) 
Rn vote Gint 20 必需 的 ) 


图 6-18 绑 定 的 数据 库 


7 6.3 在线 投 票 管理 系统 开发 


对 投票 管理 系统 来 说 需要 重点 设计 的 页 面 是 开始 投票 页 面 vote.php 和 投票 结果 页 面 
voteok.php。 计 算 投 票 页 面 voteadd.php 是 一 个 动态 页 面 , 没有 相应 的 静态 页 面 效 果 ， 只 有 累加 
投票 次 数 的 功能 。 


531 ) 开 始 投票 页 面 功能 
开始 投票 页 面 vote.php 主 要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 


然后 传递 到 voteadd.php 页 面 进行 计算 。 
详细 的 操作 步骤 如 下 : 


国 打开 刚 创 建 的 vote.php 页 面 ， 输 入 网 页 标题 “开始 投票 页 面 ”， 执 行 菜单 栏 “ 文 
件 ” 一 “保存 ”命令 将 网 页 保存 。 

园 在 则 创建 背景 图 像 的 单元 格 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ”一 “表单 ”命令 ， 
再 执行 菜单 “插入 ”一 “表格 ”命令 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 表格 中 执 
行 菜单 栏 “ 插 入 ”一 “表单 ”一 “ 单 选 按 钮 ”插入 一 个 “ 单 选 按 钮 ”， 选 择 “ 单 选 按钮 ” 
并 在 “属性 ”面板 中 将 它 命 名 为 ID， 如 图 6-19 所 示 。 


属性 
o| 单 选 按钮 选 定 值 初始 状态 〇 已 色 选 @) 类 人) 无 ~ 
Eb | 8 动态 .| 人 未 迁 中国 


图 6-19 设置 “ 单 选 按钮 ”名 称 
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执行 菜单 栏 “ 插 入 ”-， “表单 ”-、 “按钮 ”命令 插入 两 个 按钮 ， 一 个 是 用 来 提交 
表单 的 按钮 命名 为 “投票 ”， 另 外 一 个 是 用 来 查看 投票 结果 的 按钮 命名 为 “查看 ”， 效 果 
如 图 6-20 所 示 。 


二 cvwampp\htdocswotewvote php* a 
rote php 


请 你 投票 ? ?本 投票 只 可 投票 一 次 ? 


图 6-20 投票 首页 的 效果 图 
单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 莱 单 中 选择 “ 记 
录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 输入 设 定 值 ， 如 图 6-21 所 示 。 


图 6-21 “记录 集 ” 对 话 框 
绑 定 记录 集 后 , 将 记录 集中 的 字段 插入 至 vote.php 网 页 的 适当 位 置 , 如 图 6-22 所 示 。 


| yo% O99 | 
上 + 人 96 (287) 1 


{ t 
| : 
| O 〇 {Revoteiem)| : 
上 

上 上 


哄 ] 也] 


6-22 ”记录 集 的 字段 插入 至 vote.php 网 页 
国 单 击 “ 单 选 按 钮 ”将 字段 ID 绑 定 到 单 选 按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面 
板 中 的 “ 选 定 值 ” 中 添加 了 播 入 ID 字段 的 相应 代码 为 <?php echo $Srow_Rsvote['ID']; ?>， 如 
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图 6-23 所 示 。 
加 入 “服务 器 行为 ”中 “重复 区 域 ”的 命令 , 单 击 vote.php 页 面 中 的 表格 ， 如 图 6-24 


| 上 加 Me | 

| 你 投 的 选项 是 : 
ol Ch | 
Ee php eche $row_Rsvotel ID ], ?> ! | [二 E 
图 6-23 ”插入 字段 到 单 选 按钮 图 6-24 选择 记录 行 


单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 设 定 一 页 显示 Rsvote 记 录 
集中 的 所 有 记录 ， 如 图 6-25 所 示 。 


重复 区 尸 
和 Eee = 


加 118 有 康 


图 6-25 “重复 区 域 对 话 杠 
国 单 击 “确定 ”按钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设置 ， 如 图 6-26 所 示 。 


冰 cvampp\tdocswvotewvote php 
vote php 


请 你 投票 4 + 本 投票 只 可 投标 一 次 


的 选项 是 : 司 
© {Rsvote item} 
电 天 | 区 和 到 此 
| - | 
[2 目 目 国 5 25 


图 6-26 设置 重复 后 的 效果 


在 vote.php 页 面 中 ， 将 鼠标 放 在 表格 中 ， 在 “标签 选择 器 ”上 单 击 <form> 标 签 ， 并 
在 “属性 ”面板 设置 表单 forml 的 “动作 ”为 设置 投票 数据 增加 的 页 面 voteadd.php，“ 方 
法 ”为 POST， 如 图 6-27 所 示 。 
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图 6-27 设置 表单 动作 
下 面 简单 介绍 一 下 PHP $_GET 变 量 和 $_POST 变 量 。 


1. $_GET 变量 

$_GET 变量 是 一 个 数组 , 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 和 值 .$_GET 变 
量 用 于 收集 来 自 method="get" 的 表单 中 的 值 。 从 带 有 GET 方法 的 表单 发 送 的 信息 ， 对 
任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 ), 并 且 对 发 送 的 信息 量 也 有 限制 (最 多 100 
个 字符 ) 。 

在 使 用 $_GET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 中 。 所 以 在 发 送 密码 或 
其 他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 URL 中 ， 因 此 可 以 在 
收藏 夹 中 收藏 该 页 面 ， 在 某 些 情况 下 这 是 很 有 用 的 。 


2. $_POST 变量 

$_POST 变 量 是 一 个 数组 ， 内 容 是 由 HTTP POST 方法 发 送 的 变量 名 称 和 值 。 

$_POST 变 量 用 于 收集 来 自 method="post" 的 表单 中 的 值 。 从 带 有 POST 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 不 可 见 的 《不 会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送信 息 的 量 
也 没有 限制 。 

应 该 在 任何 可 能 的 时 候 对 用 户 输入 进行 验证 。 客 户 端的 验证 速度 更 快 ， 并 且 可 以 减轻 
服务 器 的 负载 。 不 过 ， 任 何 流 量 很 高 以 至 于 不 得 不 担心 服务 器 资源 的 站 点 ， 也 有 必要 担心 
站 点 的 安全 性 。 如 果 表 单 访问 的 是 数据 库 ， 就 非常 有 必要 采用 服务 器 端的 验证 。 在 服务 器 
验证 表单 的 一 种 好 的 方式 是 : 把 表单 传 给 它 自己 ， 而 不 是 跳 转 到 不 同 的 页 面 。 这 样 用 户 就 
可 以 在 同一 张 表单 页 面 得 到 错误 信息 。 用 户 也 就 更 容易 发 现 错误 了 。 


辆 单 击 页 面 中 的 “查看 ”按钮 ， 切 换 至 “标签 检查 器 ”选项 卡 ， 单 击 “ 行 为 ”面板 
下 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “ 转 到 URL” 选 项 ， 如 图 6-28 所 示 。 


图 6-28 选择 “ 转 到 URL 
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打开 “ 转 到 URL” 对 话 框 , 在 URL 文 本 框 中 输入 要 转 到 的 文件 voteok.php, 如 图 6-29 
所 示 。 然 后 单 击 “确定 ”按钮 ， 完 成 “ 转 到 URL” 设 置 。 


关 到 URL “有 | | 
站 这 | 
打开 在 : 本 
帮助 
URL voteok. php 浏览.… ] 


图 6-29 输入 ” 转 到 URL” 的 文件 地 址 


-G632 ) 计 算 投 票 页 面 功能 


计算 投票 页 面 voteadd.php, 主要 方法 是 接收 vote.php 所 传递 过 来 的 参数 , 然后 再 进行 累 
加 计算 。 计 算 投 票 页 面 voteadd.php 只 用 于 后 台 计 算 用 ， 希 望 投 票 者 在 成 功 投 票 之 后 转 到 投 
票 结果 页 面 voteok.php， 只 要 加 入 代码 header("location:voteok.php"); 到 voteadd.php 页 面 就 可 
以 完成 对 voteadd.php 页 面 的 制作 ， 本 小 节 核 心 代码 如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
ry SPOSEI EO TN 
echo " 2 目 "; 


exit (0 


)7/ 济 断 是 天 选择 了 投票 的 选项 


else 
{ 


$ID=strval ($ POST['ID']); 
// 赋 值 ID 变 量 为 上 一 页 传递 过 来 的 ID 值 
$conn = mysql connect ("localhost","root","admin"); 


/ /建立 数据 库 连 接 


if (!$conn) 

{ 

die (' 数 据 库 连 接 出 错 : ' . mysql error()); 
} 
// 如 果 数 据 库 连接 出 错 ， 显 示 错 误 


mysql select dbl("vote", $conn); 

// 查 询 vote 数 据 

mysql_ query("UPDATE vote SET vote = vote + 1 WHERE ID = '".$ID."'"); 
// 根 据 ID 更 新 数 表 vote， 并 自动 加 一 


mysql close($conn); 


header ("location:voteok.php"); 
// 转 到 voteok .php 
} 
UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table name 


SET column name = new value 
WHERE column name = some value 
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因为 SQL 对 大 小 写 不 敏感 ， 所 以 UPDATE 与 update 等 效 。 
为 了 让 PHP 执行 上 面 的 语句 , 我们 必须 使 用 mysql_query( ) 函 数 。 该 函数 用 于 向 SQL 
连接 发 送 查 询 和 命令 。 


< 633 ) 星 示 投票 结果 页 面 


显示 投票 结果 页 面 voteok.php 主 要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 
态 页 面 设计 效果 如 图 6-30 所 示 。 


图 6-30 显示 结果 页 面 设计 效果 图 


单 击 “ 应 用 程序 ”面板 群 组 中 的 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 
选择 “记录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 设 定 如 图 6-31 所 示 。 


图 6-31 设置 “记录 集 ” 属 性 
再 次 单 击 “ 应 用 程序 ”面板 中 的 “ 绑 定 ”面板 上 的 国 按钮 ， 接 着 在 弹出 的 下 拉 菜 
单 中 选择 “记录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “ 高 级 ”按钮 ， 进 
入 高 级 编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 


SELECT sum (vote) as sum 
// 选 择 Yote 字 段 进 行 计算 合计 ， 函 数 sum () 用 于 计算 总 值 
FROM vote 


// 从 数据 表 vote 中 取出 数据 
如 图 6-32 所 示 。 
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图 6-32 “记录 集 ” 对 话 框 设置 
单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 设置 ， 绑 定 记 录 集 后 ， 将 记录 集中 的 字段 插入 
至 voteok.php 网 页 中 的 适当 位 置 ， 如 图 6-33 所 示 。 


asqe 0 ~ 
so [5 + 2 (165) > 


小 计 ， {Rsvote} 票数 | EE 


he Od fe a Wd 本 目 目 国 sssx2liv 
图 6-33 字段 的 插入 


单 击 国生 按钮， 进入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 如 
下 代码 : 


<?PhP echo $row Rs['vote']; ?>/<?php echo $row Rsl['sum']; ?> 
// 相 应 百分比 的 代码 。 


辆 按 下 面 步骤 修改 此 段 代 码 。 


(1) 去 掉 “/” 前 面 的 ? > 的 “/” 后 面 的 <?php echo， 得 到 代码 : 


<?PhP echo $row Rs['vote']/ $row Rsl['sum'] ?> 


(2) 把 <?php echo 和 %> 之 间 的 代码 用 括号 括 上 ， 得 到 代码 : 


<?php echo ($row Rs['vote']/$row Rsl['sum'])?>% 


(3) 在 代码 后 面 加 入 *100， 得 到 代码 : 


<?PhP echo ($row Rs['vote']/$row Rsl['sum']) *100?>% 
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(4) 在 代码 前 面 加 入 round， 在 *100 前 面 加 入 小 数 点 保留 位 数 4， 并 用 0 括 上 ， 得 到 代码 : 

<?PhP echo round(($row Rs['vote']/Srow Rsl['sum']),4)*100?>% 

代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 段 代码 ， 所 以 将 这 段 代码 进行 
复制 ， 然 后 再 单 击 呈 按钮 ， 切 换 到 “代码 ”窗口 ， 选 择 <img> 中 的 width 的 值 将 其 代码 进行 
粘贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 面 round 和 保留 位 数 4 删 除 ， 得 
到 代码 为 : 

<?PhP echo round(($row Rs['vote']/$row Rsl['sum']),4)*100?> 


这 样 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设 置 如 图 6-34 所 示 。 


<tr bgcolor="#FFFFFF"> 
94 <td width="18%" height="25"><1abet><span class= 
"STYLE3">&nbsp; <?php echo Srow_Rs['item']; 
td> 


4)*1 
<?php echo round( ($row_Rs[ 
Li )*1663>%</span></td> 
EE <td width="42%" class="STYLE3">&nbsp; 小 计 : <?php echo 
$row_Rs['vote']; ?> 票数 &nbsp; </td> 


<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="3">&nbsps 


vey be WE Wd fm We YY WW [Te 
图 6-34 设置 图 像 的 缩放 
单 击 碟 到 按钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 
命令 ， 选 择 voteok.php 页 面 中 需要 重复 的 表格 ， 如 图 6-35 所 示 。 


国 cvampp\ntdocsWwote\woteok php" Ea 
vote. php a 
所 

.Ne [本 Daa aa. O00 iv 


图 6-35 选择 需要 重复 的 表格 


单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 国 按钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ”对 话 框 中 设 定 显示 Rs 记录 集中 的 所 
有 记录 ， 如 图 6-36 所 示 。 
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会昌 SS em 


图 6-36 “重复 区 域 ” 对 话 框 

国 单 去 “确定 ”按钮 回 到 编辑 页 面 ,会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

加 单 击 页 面 中 的 “返回 ”按钮 ， 切 换 至 “标签 <input>” 标 签 ， 再 单 击 “ 行 为 ”面板 
上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “ 转 到 URL” 选 项 ， 在 打开 的 “ 转 到 URL” 对 话 
框 中 的 URL 文 本 框 输入 要 转 到 的 文件 “vote.php”， 如 图 6-37 所 示 。 


图 6-37 输入 转 到 URL 的 文件 地 址 
单 击 “ 确 定 ” 按 钮 ， 完 成 显示 结果 页 面 voteok.php 的 设置 ， 测 试 浏览 效果 如 图 6-38 
所 示 。 


后 360 安 全 浏 澳 共 71 


志和 二 日 义 
所 | 已 | 傅 || 友 | 固 |http1127.001Nvcts ph BElY 
LN nr x Ea 男 + 


投标 结果， 
A 


B 
当 
D 


图 6-38 显示 投票 结果 页 面 的 效果 图 
< 534 ) 防 止 页 面 刷新 功能 
一 个 投票 


管理 系统 是 要 求 公平 、 公 正 的 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 
开始 系统 时 有 必要 加 入 防止 页 面 刷新 的 功能 。 
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实现 该 功能 的 详细 操作 步骤 如 下 : 


打开 开始 投票 页 面 vote.php， 把 光标 放 在 表单 中 ， 执 行 菜单 栏 “插入 ”一 “表单 ” 
一 “隐藏 域 ” 命 令 ， 插 入 一 个 隐藏 字段 voteip。 

加 单 击 隐 藏 域 国 | 图 标 ， 打 开 “ 届 性 ”面板 。 设置 隐 藏 域 的 值 为 <?php echo 
$_SERVER['REMOTE_ADDR']:?> 取 得 用 户 IP 地 址 ， 如 图 6-39 所 示 。 


tt IE 
IN 隐 字 区域 
lvoteip 值 WJ) | 人 ?php echo $_SERVER[ REMOTE_ADDR| 人 


图 6-39 设置 隐藏 域 的 值 


加 将 实现 防止 刷新 的 程序 放 到 voteadd.php 页 面 里 面 ， 打 开 前 面 制 作 的 计算 投票 页 面 
voteadd.php， 在 相应 的 位 置 加 入 代码 ， 如 图 6-40 所 示 .。 


国 campp\htdocs\vote\oteadd php* 六 

| 1 cneta http-equiv="Content-Type" content="text/htnl; charset=utf-a" /> | 
<?php 

率 1f (empty($_POST['ID'])){ 

Wal 4 echo "您 没 选择 投票 的 项 目 "; 日 

5 exit(0); 

司 } 1 

* else 

这 { 

| 18 $voteip=strval($_PosT['voteip']); 

1 1 + 
[3 12 $con = mysql_connect("localhost", "root",""); 

外 | 1 要 
es 14 1f (lscon) 
号 二 
国 16。 。 die( 数据库 连 接 出 漠 : ，. nysql_error()); 

17 } | 
[= | 
S| 19 mysql_select_db("vote", $con); 引 
EA 

| 


图 6-40 加 入 防止 刷新 的 代码 


具体 的 代码 分 析 如 下 : 
<?php 
if (empty($_ POST['ID'])){ 
echo "您 没 选择 投票 的 项 目 "; 
exit (0); 
}// 判 断 是 否 选择 了 投票 的 选项 


else 
于 


$voteip=strval($ POST['voteip']); 
// 赋 值 变 量 voteip 为 上 一 页 传递 过 来 的 voteip 值 
$con = mysql_connect ("localhost","root",""); 
// 建 立 数据 库 连 接 
4£f (!$con) 
{ 
die (' 数 据 库 连接 出 错 : ' . mysql error()); 
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} 
/ /如果 数 据 库 连接 出 错 ， 显 示 错 误 
mysql_select dbl("vote", $con); 
// 查 询 vote 数 据 库 
$sql=mysql query("select * from ip where voteid='".$voteip."'"); 
// 以 voteid=voteip 为 条 件 查 询 数 据 表 ip 
$info=mysql fetch array ($sql); 
// 从 结果 集中 取得 一 行 作为 关联 数组 info 


if ($info==true) 


// 如 果 值 为 真 , 说 明 数 据 库 中 有 IP 地 址 ,已 经 投 过 票 
{ 


header ("location:sorry.php"); 
// 转 到 voteok .php 


ext 


} 
else 
{ 
mysql_query("INSERT INTO ip (voteid) VALUES ('".$voteip."™')"); 
// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数 据 表 中 
} 


mysql_ close ($con); 


$ID=strval ($_POST['ID']); 
// 赋 值 ID 变 量 为 上 一 页 传递 过 来 的 ID 值 
$conn = mysql_connect ("1ocalhost"v "root",""); 


// 建 立 数据 库 连接 


if (!$conn) 

die (' 数 据 库 连 接 出 错 : ' . mysql error()); 
} 
// 如 果 数 据 库 连 接 出 错 ， 显 示 错 误 


mysql_select dbl("vote", $conn); 
// 查 询 vote 数 据 
mysql_query ("UPDATE vote SET vote = vote + 1 WHERE ID = '".$ID."'"); 


// 根 据 ID 更 新 数 表 vote， 并 自动 加 一 


mysql_close($conn); 
header ("location:voteok .php"); 
// 转 到 voteok .php 


2 


加 完成 防止 页 面 刷 新 设置 。 当 用 户 再 次 投票 时 ， 系统 可 以 根据 IP 的 惟一 性 进行 判断 。 
当 用 户 再 次 投票 的 时 候 ， 将 转 到 投票 失败 页 面 sorry.php， 页 面 设计 如 图 6-41 所 示 。 
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巧 360 安 全 浏览 器 7.1 


|[€|| | 全 || 太 |[@|httpy/127.0.0.1/vote/sorry.php 


对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 ! 


查看 结果 


6-41 投票 失败 页 面 效果 图 
在 sorry.php 页 面 有 两 个 页 面 链接 ，“ 回 主页 面 ”链接 到 vote.php， 
voteok.php。 


记 6.4 ， 在 线 投票 管理 系统 测试 


投票 管理 系统 设计 完了 以 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 F12 键 或 打开 正 浏览 
器 输入 http://127.0.0.1/ vote/vote.php 即 可 开始 进行 测试 。 测 试 步骤 如 下 : 


“查看 结果 ”链接 到 


E0071 


贺 打开 Dreamweaver 中 的 vote.php 文 件 ， 开 始 投票 页 面 效 果 如 图 6-42 所 示 。 


EE 
不 | 人 || 会 | 太 | @@ hrp//127.0.0.1Norefvote.pnp 


人 折 要 4， 丰 机 要 所 可 委 标 - 议 + 


他 
© aA 
o 

© 

© 


轿 
图 6-42 打开 的 开始 投票 页 面 
不 选择 任何 选项 ， 单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 没 选择 投票 的 项 目 ”， 如 
图 6-43 所 示 。 
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巧 360 安 全 浏览 器 7.1 人 邯 羊 曾 一口 x 
所 | 二 会 | 太 || 加 |httpy/127.0.01/ BEY 


您 没 选择 投票 的 项 目 


图 643 没 选择 项 目 错误 提示 


选择 投票 项 的 其 中 一 项 ， 再 单 击 “投票 ”按钮 ， 开 始 投票 。 

单 击 “投票 ”按钮 后 ， 打 开 的 页 面 不 是 voteadd.php， 因 为 voteadd.php 只 是 计算 投 
票数 的 一 个 统计 数字 页 面 ， 打 开 的 页 面 是 显示 投票 结果 页 面 voteok.php，voteok.php 页 面 是 
voteadd.php 转 过 来 的 一 个 页 面 ， 效 果 如 图 6-44 所 示 。 


后 360 安 全 六 学 蓝 7 和 曾 一 口 xX 
所 | 人马 儿 全 | 友 j| 因 | http//127.0.0.1voteyvoteok Php EY 


图 6-44 ”显示 投票 结果 页 面 效果 图 


单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote.php 中 。 当 用 户 再 次 投票 时 ， 将 打开 投票 失 
败 页 面 sorry.php， 如 图 6-45 所 示 。 


对 不 起 ,你 已 投 过 一 次 票 了 ,请 不 要 多 次 投票 ! 
回 主页 面 查看 结果 


图 645 提示 已 经 投票 


通过 上 面 的 测试 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 ， 读 者 可 以 看 到 在 线 投 
票 管理 系统 的 开发 并 不 难 ， 用 户 可 以 根据 需要 修改 投票 的 选择 项 ， 经 过 修改 后 的 投票 系统 
可 以 适用 于 任何 大 型 网 站 。 
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全 程 实例 五 : 留言 短 管 理 系统 


网 站 留言 簿 管理 系统 的 功能 主要 是 实现 网 站 的 访问 者 和 网 站 管理 者 的 一 个 交互 性 , 访 
问 者 可 以 向 管理 者 提出 任何 意见 和 信息 ， 管 理 者 可 以 在 后 台 及 时 回复 。 因 此 ， 学 习 PHP 
开发 动态 网 站 时 ， 留 言 得 管理 系统 的 学 习 也 是 必 不 可 少 的 。 本 章 就 使 用 PHP 开 发 一 个 可 以 
进行 留言 并 进行 回复 的 留言 簿 管理 系统 ， 开 发 的 技术 主要 涉及 数据 库 留 言 信息 的 插入 、 回 
复 和 修改 信息 的 更 新 等 ， 在 涉及 回复 时 间 时 还 会 涉及 到 一 些 关 于 PHP 时 间 函 数 的 设置 问 
题 。 


本 章 的 学 习 重 点 : 
@ 留言 簿 管理 系统 的 整体 规划 


数据 库 的 建立 方法 
留言 薄 管 理 系统 常用 功能 的 设计 
后 台 管理 系统 的 设计 


@ @ @ 
x 


PP 网站 开发 全 程 实例 (第 2 版 ) 
全 受 Wa @D。 
有 17:1 ”留言 簿 管理 系统 规划 


留言 簿 管理 系统 的 主要 功能 是 在 首页 上 显示 留言 ,管理 者 能 对 留言 进行 回复 、 修 改 和 删除 ， 
因此 一 个 完整 的 留言 夭 管 理 系 统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 


< 7.1.1 ) 页 面 规划 设计 
在 本 地 建立 站 点 文件 夹 gbook， 将 要 制作 的 留言 短 系 统 文件 夹 及 文件 如 图 7-1 所 示 。 


加 eel=>") 
具 ， 计 算 只 ，Acer (C) » xampp » htdocs » gbook » ~ | we gbook 门 | 
| xx#m。 全 日。 下 看 M 工具 大吉 由 

组 织 ” 。 疗 打 开 ”到 寻 。 新 建文 伯 关 三 BB ©@ 
祥 收 襄 夫 和 寺 

Dl Creative Cloud Bi _mmServerScripts 

六 下 吉 BR notes 

到 点 9 comecions 

到 二 Ea | dte 

himages 
min.pht 
eg Eh Wi 
目 adminJoginphp 

Ban bookphp 

pd delbook.php 8 KB 

站 文 咎 Lindexphp 了 2 

部 迅 竺 下 载 口 repyphp 9KB 

二 音乐 

六 indexphp 售 改 日 其 2011/7/12 1005 。。 全 建 B 哆 2014/12/9 17:17 
PHP 文件 六 js 1L1 KB 


图 7-1 站 点 规划 文件 
本 系统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 7-1 所 示 。 
表 7-1 系统 页 面 说 明 表 
页 面 名 称 功能 


显示 留言 内 容 和 管理 者 回复 内 容 
php 提供 用 户 发 表 留 言 的 页 面 


| bookptp | 
管理 者 对 一 些 非法 留言 进行 删除 的 页 面 


€ 系统 页 面 设计 


网 页 美工 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 左右 布局 结构 ， 留 言 页 
面 效果 如 图 7-2 所 示 。 


2 


”第 7 章 全 程 实例 五 ， 留 言 往 管理 系统 
A 


ET 


-加 多 会 和 寅 [np0moousboa 


® WK 1 和 
fe, td 
~ ~ “PHP 留言 管理 系统 - = 
8 

4 外 加 言 尖 


加 昌 关 有 什么 凡是 要 和 内 笑 ， 击 间 市 区 言 维 获知 ,我 会 荣 问 给 你 答复 


吉庆 在 名言 安 : 


:MP SEA 


图 7-2 留言 簿 管理 系统 首页 
7.2 系统 数据 库 设计 
制作 留言 簿 管理 系统 ， 首 先 要 设计 一 个 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回 
复 以 及 管理 员 账 号 、 密 码 的 数据 库 文件 gbook， 以 方便 管理 和 使 用 。 
-入 721 数据库 设 计 
本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ， 


见 表 ” 命 名 为 gbook，“ 管 理 信息 表 ” 命 名 为 admin。 
制作 的 步 又 如 下 : 


“留言 信息 意 


在 phpmyAdmin 中 建立 数据 库 gbook， 单 击 量 数据 库 命令 打开 本 地 的 “数据 库 ” 管 理 
页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 gbook， 单 击 后 面 的 数据 库 类 型 下 拉 
列表 框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选 项 ， 单 击 “ 创 建 ” 按 钮 返回“ 常规 设 
置 ” 页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 gbook 的 数据 库 ， 如 图 7-3 所 示 。 


127.0.0./ ocahost | pnoMAGmn 3.5.0 -ER2® 35 下 


司马 - 国 记 会 的 请 [Bmonr 5 -i A [4 a 
se 
区 9 


phpMyAdmin a 
人 0 “Fs Ws Nr st BIA PUR HAs ns 


图 7-3 开始 建立 数据 库 


EEY3 -TITEL 
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多 ep。 


加 单 击 左边 的 gbook 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数 据 表 ”页 面 ， 分 别 输入 数据 表 
名 gbook 和 admin ( 即 创建 2 个 数据 表 ) ， 设 计 gbook 的 字段 结构 如 表 7-2 所 示 。 输 入 字段 名 
以 及 设置 数据 类 型 的 相关 数据 ， 如 图 7-4 所 示 。 


表 7-2 ”留言 信息 意见 表 gbook 


字段 名 称 

ID INTEGER 

subject VARCHAR 

content TEXT 
TEXT 


[re | wrcuar [so | 十 
VARCHAR 2 


全 road1 ochos | ohook ook | phpMyAamn 3.5.0 -人 四 3.5 
本 己 - 瑟 多 会 和 并 12700.1 mal 汪 
六 加 

+ DE 


phpMyAdmin 
多国 司 加 了 JS | 和 的 局 SQL | 居所 A 习 5 册 同和 坟 归 人 污 坟 A 
[0 (Ya PHP fe ] 
[Ee 上 名字。 关 型 要 于 上 性 空 冉 人 关外 烘 作 
[pn on mo 可 无 “AUTO_NCREMENT 才华 收 全 加 R 划 
EE 口 > eublect varcharED) wgenaral i 可 无 ON KS 
‘hook 口 3 conmtenmt wat ] 彬 SO NS v KS 
i Drepy tod un 是 NULL Sut ON vs 
号 五 SE © NR EE 
是 MG om D WR 更 了 
可 天 DN 
如 更 i 
全 人 过 /全 不 连 葵 p 汪 ， 辐 洛 态 信 光合 草 $ 疙 三 全 面 二 一 国 宗 引 
ET TE 
Bm0 | 人 了 加 于 于 5 区 OO 于 天 二 所 [0 司 上 的 全 
,a3l 到 


CE PTETLD 


图 7-4 创建 的 数据 表 gbook 
加 创建 admin 数 据 表 ， 参 见 表 7-3。 用 于 后 台 管 理 者 登录 验证 ， 输 入 数据 域名 以 及 设 
置 数据 域 位 的 相关 数据 ， 如 图 7-5 所 示 。 


表 7-3 ”管理 信息 数据 表 admin 


字段 名 称 类 型 字段 大 小 

id INTEGER 长 整 型 
| username VARCHAR 50 是 
| password VARCHAR 50 是 


= 


司 忆 - 司 多 全 和 将 [Sr nl 四 EFFECTET a 


英信 马 呈 由 辣 号 入 产 类 作 ， 工 直 大 


YNy5oL 这 可 的 关 和 4 呈 凡生 本。 【 训 交 页 由 0008 著 ) 


Da Mpa 1 全 so [eve aH fe 11 AF 1 


后 性 空 要 认 部 放生 入 
机 到 ROM nS 


EE 
二 三 FO 
机 日 6a Ds 人 国 本 | 
CEE . 
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图 7-5 创建 的 admin 数据 表 
数据 库 创建 完毕 以 后 ， 对 于 本 系统 而 言 下 一 步 是 如 何 取 得 访问 者 的 IP 地 址 。 
DS 7.2.2 ) 定 义 系统 站 点 


在 Dreamweaver CC 中 创建 一 个 “留言 秒 管 理 系统 ”网 站 站 点 gbook， 由 于 这 是 PHP 数 
据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 7-4 所 示 。 


表 7-4 ”站 点 设置 的 基本 参数 


站 点 名 称 
本 机 根 目录 
测试 服务 器 
网 站 测试 地 址 

MySQL 服 务 器 地 址 
管理 账号 / 密码 


gbook 
创建 gbook 站 点 具体 操作 步骤 如 下 : 


加 首先 在 C:xampp\htdocs 路 径 下 建立 gbook 文 件 夹 ( 如 图 7-6 所 示 ) ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 底下 。 


[EE =| 
GO Hen , xe , wmpp , ndces » BE EI 万 
HD MR 23M IRM mm 

RR” 喇 3 乒 “Sa JJ 尝 "和 53Exf 关 si ee 


吾 杷 F 中 


book 全 隔 2014/1281747 
二 


中 | 


图 7-6 建立 站 点 文件 夹 gbook 


i 


‘Oe 


> LY 
“Mg 网 站 开发 全 程 实例 (第 2 版) 


因 运行 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ” 


一 “管理 站 点 ”命令 ， 打 开 “ 管 
理 站 点 ”对 话 框 ， 如 图 7-7 所 示 。 


图 7-7 “管理 站 点 ”对 话 框 
国 对 话 框 的 上 面 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 角 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 gbook” 对 话 框 ， 进 行 如 图 7-8 所 示 的 参数 设置 。 


Dreamweaver 让: 


ad 中 全 信人 的 和 全 Dreamer 
过 抽 Ei 和 名 当 
[2 


闪避 以 在 此 星 为 pyeswwweyver 让 占 这 程 去 件 二 和 各 和 
Pe Er 


ET 目 


图 7-8 建立 gbook 站 点 


单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 Ej， 打开 “基本 ” 
选项 卡 进行 如 图 7-9 所 示 的 参数 设置 。 


si ] 三 
| 用 各 各 m: [che J 
证 这 二 :| 二 Wb 近 
Mn ，，，，， 马 
as[eewaoava | 醒 一 
全 | 陋 
WW | 芳 |] 王 彬 | 


图 7-9 设置 “基本 ”选项 卡 
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加 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选 项 ， 表 示 是 使 用 PHP 
开发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-10 所 示 。 


和 
版 本 控 省 | 远程 服务 器 
| 高 骂 设 慎 区 维护 司 步 信息 ww 并 
口 保存 时 自动 符 文件 上 传 到 服务 器 
口 自用 文件 取出 了 能 
区 打开 文件 之 前 取出 pait 


服务 器 模型 :PHPwySL | 
ED EE 了 I 
LL ww | 全 C 驶 | 


图 7-10 设置 “高 级 ”选项 卡 
国 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 图 7-11 


所 示 。 
| Em 您 将 在 此 位 置 法 了 加 web 上 的 页 面 的 了 务 器 。 此 对 话 杠 的 设 加 下 | 
et 服务 提供 商 (ISP) 或 web 管理 员 、 
高 级 设置 | 
> Ew 您 无 需 完 成 此 步 邓 。 如 果 要 连接 到 Web 并 发 
| | | T 
gbock Chramop/htdocs TV TF 
| 
mi 
EE 到 


图 7-11 设置 “服务 器 ”参数 


单 击 “ 保 存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 
刚才 所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关 闭 “管理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CC 测试 留言 簿 管理 系统 网 页 的 网 站 环境 设置 。 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ; 网 站 与 数据 库 
的 连接 设置 如 下 : 


将 设计 的 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index.php， 如 图 7-12 所 示 。 


Be 


a 人 人 (第 2 版 ) 


SC er 
主 襄 辣 而 命 地 此: 二 


ia wu | usw uno ly 本 
ED Eg eo 
EC oD 


图 7-12 打开 网 站 首页 
单 击 菜单 栏 上 的 “窗口 ” 一“ 数据库” 命令， 打开 “数据 库 ” 面板。 在 该 面板 上 
单 击 “+” 图 标 ， 在 打开 的 下 拉 菜 单 中 选择 “MySQL 连 接 ” 选 项 ， 如 图 7-13 所 示 。 


.设置 站 点 的 测试 服务 器 , 
。 单 击 上 面 的 + 按钮 创建 连接 。 


图 7-13 选择 “MySQL 连接 ” 
在 “MySQL 连 接 ” 对 话 框 中 ， 输 入 “连接 名 称 ” 为 gbook、“MySQL 服 务 器 ”名 
为 localhost、“ 用 户 名 ”为 root、“ 密 码 ” 为 空 。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 
击 “ 和 选取 ”按钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 gbook， 具 
体 的 设置 内 容 如 图 7-14 所 示 。 
MysQL 过 本 


连接 名 称 :|book 
MySQL 服务 器 : hocalhost 
用 户 名 : root 
密码 : 
数据 库 : gbook 


二 一 = 


图 7-14 设置 MySQL 连接 参数 
单 击 “ 测 试 ”按钮 测试 与 MySQL 数 据 库 的 连接 是 否 正确 ， 如 果 正 确 则 弹出 提示 消 
息 框 (如 图 7-15 所 示 ) ， 这 表示 数据 库 连 接 设置 成 功 了 。 


- 248 - 


图 7-15 提示 设置 成 功 


加 单 去 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数 
据 库 ， 如 图 7-16 所 示 。 


名 content (text 必需 的 ) 
9 date (date 必需 的 ) 


989 ID Gnt 11 必需 的 ) 
了 IP (varchar 50 必需 的 ) 
8 passid Crercher 20 必须 的 ) 


Re redate (date 必须 的 ) 

BD reply (text) 

了 subject (varchar 50 必需 的 ) 
四 -加 视图 
田 - 考 预存 过 程 


图 7-16 绑 定 的 数据 库 
有 7:3 ”留言 簿 首页 和 留言 页 面 


留言 簿 管理 系统 分 前 台 和 后 台 两 部 分 , 这 里 首先 制作 前 台 部 分 的 动态 网 页 。 主要 有 留言 血 
首页 index.php 和 留言 页 面 book.php。 


TD 贸 言 短 首 页 


在 留言 短 首 页 index.php 中 ， 单 击 “ 留 言 ” 超 链接 时 ， 打 开 留 言 页 面 book.php， 访 问 者 
可 以 在 上 面 自由 发 表意 见 ， 但 管理 人 员 可 以 对 恶性 留言 进行 删除 、 修 改 等 。 
其 详细 制作 的 步骤 如 下 : 


打开 静态 页 面 index.php， 然 后 在 “现在 时 间 是 : ”后 面 加 一 个 PHP 代 码 : 


<?PhP 

date default timezone set('Asia/Shanghai'); 
echo date("Y-m-d h:i:s"); 

2 


得 到 系统 当前 时 间 ， 在 文字 “留言 ”上 作 一 个 超 链接 ,链接 到 book.php， 效果 如 图 7-17 
所 示 。 


:和 


夯 cyampp\ntdocs\gbookindex php* -Ox 
shook php 


图 7-17 首页 的 效果 图 


执行 菜单 栏 “ 窗 口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 的 国 按 
钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 在 该 对 话 框 中 进行 如 下 设置 : 


@ 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 “记录 集 ” 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 
@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
@ 在 “ 列 ” 单 选 按钮 组 中 选中 “全 部 ” 单 选 按钮 。 
完成 后 的 设置 如 图 7-18 所 示 。 
记录 集 A 
i 名 称 : Rs 
连接 : [sbook SE 
表格 :|gbook 四 
列 : 回 全 部 选 定 的 : 
| ss 加 
筛选 : | 无 - 
| 输入 的 值 
排序 :| 无 到 [升序 


图 7-18 “记录 集 ” 对 话 框 


辆 单 击 “高 级 ”按钮 ， 进 行 高 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 

SELECT * 

FROM gbook // 从 数据 库 中 选择 gbook 表 

WHERE passid=0 // 选 择 的 条 件 为 passid 为 0 

当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字 段 值 为 0 的 记录 时 , 表示 此 留言 已 
经 通过 管理 员 的 审核 ， 如 图 7-19 所 示 。 
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第 7 章 全 程 实例 五 : 留言 筹 管理 系统 上 
。， ”60Ge 


图 7-19 输入 SQL 语句 


单 击 “ 确 定 ”按钮 ， 完 成 记录 集 的 绑 定 ， 然 后 将 此 字段 插入 至 index.php 网 页 的 适 
当 位 置 ， 如 图 7-20 所 示 。 


lboay” table” tr Wd able W Wd fn. be 


图 7-20 绑 定 字段 
在 “管理 回复 ”单元 格 中 ， 根 据 数据 表 中 的 回复 字段 reply 是 否 为 空 ， 来 判断 管理 
者 是 否 访问 过 。 如 果 该 字段 为 空 ， 则 显示 “对 不 起 ， 暂 无 回复 ! ”字样 信息 ， 如 果 该 字段 
不 为 空 ， 就 表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 
在 设计 视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 ! ”字样 ， 
并 加 入 代码 ， 如 图 7-21 所 示 。 
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图 7-21 加 入 代码 
<?php 


if ( $row_Rs['reply']= empty( $row Rs['reply'])) { 
echo "对 不 起 ， 暂 无 回复 ! ";} // 如 果 reply 字 段 为 空 则 显示 


else{ ?> // 如 果 不 为 空 则 显示 以 下 的 内 容 
<br /> 


管理 员 在 <?php echo $row_Rs['redate']; ?> 回复 内 容 : <br /> 


<?php echo $row Rs['reply']; }?> 


由 于 index.php 页 面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数据 ， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 选 择 index. asp 页 


面 中 需要 重复 显示 的 内 容 ， 如 图 7-22 所 示 。 


Dw ”> mk BBW SA) FsM) ER(O) ssIO as) SOW) welt 


+ 


1 [7 到 要 央 。 时 。 :SEE 


在 人 Rs mcs) 加 页 具 容 : 


[EE| 各 le AoE sj ea 
一 - cs 3 sliSpace C eraerD 


记录 集 Ga) 
动态 文本 Oh aukjeeU) 
动态 文本 0ks TD) 
动态 文本 Ga.IT) 
幼 广 本 hs. entent) 
动 本 文本 (Ls.zetats) 
EE 0 rel) 


图 7-22 ”选择 要 重复 显示 的 内 容 
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第 7 章 ”全程 实例 五 : 留言 短 管 理 系统 (0 
*@ 


国 单 南 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 中 的 国 按钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 设 定 显示 的 数据 选项 ， 如 
图 7-23 所 示 。 


图 7-23 “重复 区 域 ”对 话 框 
单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 , 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 “ 重 
复 ” 的 灰色 标签 ， 这 表示 已 经 完成 设 定 了 。 
将 鼠标 指针 移 至 要 加 入 “记录 集 导航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ”类 别 
中 单 击 国 工具 按钮 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 , 然后 单 
击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 此 时 页 面 就 会 出 现 该 记录 集 的 导航 条 ， 效果 如 图 7-24 所 示 。 


DW 交 伯 (月 。 注 坟 (F) 喜 枉 V) 插 ND 修改 (MI 桥 (O) 会 S(O 尖 S(S) 证 DOW) 台山 (H) me: | Ea OLl=lol x 


Indexphpr x SDK CUP MITTEN ry 
MR cbock php 号 全 
一 本 EPE 


一 | 本 地 视图 - 
ask ehh 
一 2 


-2 ols + | 


jE phy 
i 


pe a [ET 


Em | iJ 计 rv| quws 雹 | 

ispsee | Joréer 0 
各 客站 ee 加 日 站 
Bb 


i a lo 


-lsd 


‘Em ; 
EE 


图 7-24 ”加 入 “记录 集 导 航 条 


将 饼 标 指针 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ” 列 的 “数据 ”类 别 中 单 击 圈 工 
具 按 钮 ， 在 弹出 的 对 话 框 中 选取 要 显示 状态 的 记录 集 ， 再 单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 
面 ， 此 时 页 面 就 会 出 现 该 记录 集 的 导航 状态 ， 如 图 7-25 所 示 。 
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图 7-25 加 入 “记录 集 导 航 状 态 ” 

留言 的 首页 index.php 设 计 完 成 。 打 开 IE 浏 览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/ 
gbook/ index.php， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 如 图 7-26 
所 示 。 


EE 7 "3 
拟 | 切 | 会 | 六 | 加 nrip://127,0.0.1/gb BEY 
EET * 置 
We 


是 
用 户 和 罗 = 入 
害 到: CD 
人 有 什么 朵 归 要 吉大， 请 二 全 言 乱 寺 ， 折 站 二 拓 各 弛 和 
国 锣 这 到 64 日 
EP Be i 
EE 
WO: TF, $A! | 
aes 加 加 
SERVICE/OT Fa 
7-26 ”留言 簿 管理 系统 主页 测试 效果 图 
/ 


7.3.2 留言 页 面 


本 节 将 要 制作 访问 者 在 线 留言 功能 ， 通过 “服务 器 行为 ”面板 中 的 “插入 记录 ”功能 ， 
实现 将 访问 者 填写 的 内 容 插 入 到 数据 表 gbook 中 。 
制作 步骤 如 下 : 


执行 菜单 栏 “ 文 件 ” 一 “新建” 命令 打开 “新 建文 档 ” 对 话 框 ， 创 建新 页 面 ， 执 
行 菜单 栏 “ 文 件 ” 一 “另存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 保存 为 book.php。 
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供 访问 者 留言 的 静态 页 面 book.php， 与 主页 面 index.php 大 体 一 致 ， 页 面 效 果 如 图 
7-27 所 示 。 


FE -BI Sn 

ao - 本 中 
i 本 器 国 
有 nl a] 


图 7-27 设计 的 页 面 效果 
在 留言 簿 表单 内 部 ， 分 别 执行 三 次 “插入 记录 ”一 “表单 ”一 “隐藏 区 域 ”命令 
插入 三 个 隐藏 区 域 ， 选 中 其 中 一 个 隐藏 区 域 ， 将 其 命名 为 了 也， 并 在 属性 面板 中 对 其 赋值 ， 
如 图 7-28 所 示 。 


<input name="TP” type="hidden" id="IP" value="<?php echo 
$_SERVERI['REMOTE ADDR'];?>" /> 
// 自 动 取 得 用 户 的 TP 地 址 


值 轨 | 人 ?php echo $_SERVER[ RENOTE_ADDR| 妈 


图 7-28 设 定 IP 值 
再 选择 另外 一 个 隐藏 区 域 命 名 为 date， 并 在 “ 值 ”文本 框 中 输入 获取 系统 时 间 的 
代码 ， 如 图 7-29 所 示 。 


<input name="date" type="hidden" id="date" value="<?php 
date default timezone set('Asia/Shanghai'); 
echo date("Y-m-d h:i:s"); 
Sn 
// 获 取 系 统 即 时 时 间 
属性 


| ss 
date 导入 [Gphpdate_defanlt_tinerzone_set(] 多 
图 7-29 设置 时 间 


加 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid、“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 
时 生成 的 passid 值 为 0, 管理 者 可 以 根据 这 个 值 进 行 判 断 , 方便 后 面 的 管理 ， 如 图 7-30 所 示 。 
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图 7-30 设置 passid 值 为 0 
国 单 击 “ 应 用 程序 ”一 “服务 器 行为 ”面板 中 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 
“插入 记录 ”选项 ， 在 打开 的 “插入 记录 ”对 话 框 中 设置 参数 ， 在 “ 列 ” 列 选项 中 会 自动 
配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 插入 使 用 的 。 完 成 后 的 设置 如 图 
7-31 所 示 。 


图 7-31 -插入 记录 对 话 框 

单 击 “确定 ”按钮 ， 回 到 网 页 设计 编辑 页 面 ， 就 完成 页 面 book.php 插 入 记录 的 设 
置 。 

国 有 些 访问 者 进入 留言 页 面 book.php 后 ， 不 填 任何 数据 就 直接 把 表单 送出 ， 这 样 数 
据 库 中 就 会 自动 生成 一 笔 空白 数据 ,为 了 阻止 这 种 现象 发 生 ， 须 加 入 “检查 表单 ”的 行为 。 
具体 操作 是 在 book.php 的 标签 检测 区 中 , 单 击 <formml> 这 个 标签 ， 然 后 再 单 击 “ 行 为 ”面板 
的 [加 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 。 

园 “检查 表单 ”行为 会 根据 表单 的 内 容 来 设 定 检查 方式 ， 留 言 者 一 定 要 填 入 标题 和 
内 容 ， 因 此 将 subject、content 这 两 个 字段 的 值 设置 为 “必需 的 ”， 这 样 就 可 完成 “检查 表 
单 ”的 行为 设 定 了 ， 具 体 设置 如 图 7-32 所 示 。 


图 7-32 选择 并 设置 必 填 字段 
单 击 “确定 ”按钮 ， 完 成 留言 页 面 的 设计 ， 如 图 7-33 所 示 。 
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图 7-33 ”完成 的 页 面 设计 
2 7.4 系统 后 台 管 理 功能 


留言 每 后 台 管 理 系统 可 以 使 系统 管理 员 通过 admin_login.php 进 行 登 录 管 理 ， 管 理 者 登 
录入 口 页 面 的 设计 效果 如 图 7-34 所 示 。 


图 7-34 ”系统 管理 入 口 页 面 
< 7.4.1 ) 管 理 者 登录 入 口 页 面 
管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受 到 权限 约束 。 详 细 操 作 步 又 如 下 : 


打开 制作 的 静态 页 面 admin login.php。 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ” 
标签 上 的 团 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “用 户 身份 验证 /登录 用 户 ” 选 项 ， 弹 出 “ 登 
录用 户 ” 对 话 框 ， 在 对 话 框 中 设置 “如 果 登 录 失 败 ， 转 到 ”为 index.php、“ 如 果 登 录 成 功 ， 
转 到 ”为 admin.php， 如 图 7-35 所 示 。 


图 7-35 “登录 用 户 ” 对 话 框 
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执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 该 面板 中 的 团 按 
钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 弹 出 “检查 表单 ”对 话 框 ， 设 置 username 
和 password 文 本 域 的 “ 值 ” 都 为 “必需 的 ”、“ 可 接受 ”为 “任何 东西 ”， 如 图 7-36 所 示 。 


图 7-36 “检查 表单 ”对 话 框 
单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 管 理 者 登录 入 口 页 面 4dmin_login.php 的 设计 
与 制作 都 已 经 完成 。 


< 了 742 管理 页 面 


后 台 管 理 页 面 admin.php 是 管理 者 由 登录 页 面 验证 成 功 后 所 跳 转 到 的 页 面 。 这 个 页 面 提供 
删除 和 编辑 留言 的 功能 ， 效 果 如 图 7-37 所 示 。 


| 动 cvamppihtdocs\gbooladmin php" SI 
TD cbork nphp 了 


Copraightaa01L201 boule com Inc Aughts reserved 开 情 文化 版 权 所 有 


站 a 


目 目 量 1716x302 


图 7-37 “管理 页 面 ”的 设计 效果 

操作 步骤 如 下 : 

贺 打开 admin.php 页 面 ， 此 页 面 设计 比较 简单 ， 在 这 里 不 作 说 明 ， 单 击 “ 绑 定 ” 面 板 
上 的 团 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ” 选项， 打开 “记录 集 ” 对 话 框 ， 
在 该 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 gbook。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮。 
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@ 设置 “排序 ”方法 为 以 ID 降序 。 
单 击 “ 确 定 ” 按 钮 完成 设 定 ， 如 图 7-38 所 示 。 
Es 区 本 | 


图 7-38 “记录 集 ” 对 话 框 
绑 定 记录 集 后 ， 将 记录 集 字 段 插入 至 admin.php 网 页 的 适当 位 置 ， 如 图 7-39 所 示 。 


9 A th oo 用 
= “PHP 留言 久 理 系统 2” 


KI vey le We a me a le WW [TD 
图 7-39 ” 乡 定 的 字段 
admin.php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 ,而 目前 的 设 定 则 只 会 显示 数据 


库 的 第 一 笔 数 据 ， 需 要 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 命令 ,选择 admin. asp 页 面 中 
需要 重复 显示 的 区 域 ， 如 图 7-40 所 示 。 


目 目 呆 75>x scv 


二 35% 0 | 
村 一 -一 0 
编 。 。” 注 是 殉 容 下 营 理 
NRsID} JRssujcl jnscmtotl her) NM ag | 


图 7-40 选择 要 重复 的 内 容 


单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 团 按 钮 ， 在 弹出 的 下 拉 菜 
单 中 选择 “重复 区 域 ”选项 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 设置 一 页 显示 的 数据 选项 ， 
例如 10 条 记录 ， 如 图 7-41 所 示 。 


- 259 - 


Sale J (第 2 版 ) 
名 ‘ve 


图 7-41 “重复 区 域 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左 上 角 出 现 了 一 个 
a 的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
国 选取 记录 集 有 记录 时 ， 要 显示 的 记录 表格 如 图 7-42 所 示 。 


CE -ox 

| SY dre ba 

| | 上 
“PHP 留 言 息 理 系统 ~ c 
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me EE EE ] 
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0 rm 


图 7-42 选择 有 记录 和 显示 页 面 


单 击 “ 服 务 器 行为 ”面板 中 的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “显示 区 域 / 如 
果 记 录 集 不 为 空 则 显示 区 域 ” 选项 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 
选择 “记录 集 ” 下 拉 列 表 框 中 的 Rs 选项 ， 再 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先 
前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表 
示 已 经 完成 设 定 了 ， 如 图 7-43 所 示 。 


二 campp\htdocs\gbook\admin php- 村 
NY ebook php ?| 


硬 
sh an 出 抽 用 好 


i “Ph 加 二 PR 


ee 


图 7-43 完成 的 设置 
国 输入 记录 集 没 有 记录 时 要 显示 的 内 容 “ 目 前 没有 任何 留言 ”， 如 图 7-44 所 示 。 
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图 7-44 选择 没有 记录 要 显示 的 页 面 内 容 


单 击 “服务 器 行为 ”面板 中 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “显示 区 域 / 如 
果 记 录 集 为 空 则 显示 区 域 ” 选 项 ， 在 打开 的 “如 果 记 录 集 为 空 则 显示 ”对 话 框 中 的 “记录 
集 ” 下 拉 列 表 框 中 选择 Rs 选项 ， 如 图 7-45 所 示 。 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 
现 先前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 
这 表示 已 经 完成 设 定 了 。 


图 7-45 设置 “如 果 记 录 集 为 空 则 显示 ”对 话 框 
将 光标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “应 用 程序 ”类 别 
中 ， 单 击 国 工具 按钮 ， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 然 后 
单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 7-46 所 示 。 


画 cwampp\ntdocsgbookadminphp- 可 -和 
EY book phy nA 


-| 
日 晶 时 x3 


图 7-46 ”加 入 “记录 集 导 航 条 ” 
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单 击 页 面 中 的 “回复 ”文字 , 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ,并 单 击 “ 浏 
览 文 件 ” 图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 reply.php， 设 置 如 图 
7-47 所 示 。 


zolaytareles6 。 立 
201a71219 17:17 


[easy Eweah [ew | 


图 747 选择 链接 文件 


单 击 “ 确 定 ” 按 钮 ,设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 reply.php?ID=<?php 
echo Srow_Rs['ID']; ?>， 值 设置 如 图 7-48 所 示 。 


Po 


DC) 无 


单元 格 。 水 平 2) [最 ] 克 ) 不 搞 行 中) 门 1 Ce 
一 交 三 中 敬 


图 7-48 “参数 ”对 话 框 
单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 选 取 编 辑 页 面 中 的 “删除 ”二 字 ， 在 “属性 ” 
面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 
详细 记录 信息 的 页 面 delbook.php， 并 设置 传递 ID 参数 ， 如 图 7-49 所 示 。 


图 7-49 设置 “删除 ”的 链接 


单 击 “ 确 定 ” 接 钮 ， 回 到 编辑 页 面 ， 单 击 “应 用 程序 ”面板 中 的 “服务 器 行为 ” 
标签 上 的 图 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “用 户 身份 验证 /限制 对 页 的 访问 ”选项 ， 在 
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打开 的 “限制 对 页 的 访问 ”对 话 框 中 设置 “如 果 访 问 被 拒绝 ， 则 转 到 ”为 admin_login.php 
页 面 ， 如 图 7-50 所 示 。 


基于 以 下 内 容 进 行 限制 : 加 “用户 客 和 于 三 


出 


局 ”用 户 名 、 密码 和 访问 好 别 
碗 职级 别 - 


如 果 访 问 被 拒绝 ， 则 转 到 - sdain_login php 


图 7-50 “限制 对 页 的 访问 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 就 完成 了 后 台 管理 页 面 admin.php 的 制作 。 


7243 问 复 留言 页 面 


回复 留言 的 功能 主要 通过 reply.php 页 面 对 用 户 留言 进行 回复 ， 实 现 的 方法 是 将 数据 库 的 
相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 填写 内 容 ， 单 击 “ 回 复 ” 按 钮 ， 可 以 将 回复 
内 容 更 新 到 gbook 数据 表 中 ， 页 面 效果 如 图 7-51 所 示 。 


翅 cwampp\ntdocs\gboolvreply pnp* -Ox 
ITED cbork rho 


RE | i 
4 下 
FDI 村 NE 于， 二 NE i od on Moml IE IE a 上 15200 
图 7-51 回复 留言 页 面 
动态 功能 的 制作 步骤 如 下 : 


贺 创建 reply.php 页 面 ， 并 单 击 “ 绑 定 ” 面 板 上 的 图 按钮 ， 在 弹出 的 下 拉 菜 单 中 ， 选 
择 “ 记 录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 

@ 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 gbook。 

@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 

@ 设置 “筛选 ”的 方法 为 : ID =URL 参 数 ID。 

单 击 “ 确 定 ” 按 钮 完成 设 定 ， 如 图 7-52 所 示 。 
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图 7-52 设置 绑 定 的 “记录 集 “ 
贺 绑 定 记录 集 后 ， 再 将 绑 定 字段 插入 至 reply.php 网 页 的 适当 位 置 ， 如 图 7-53 所 示 
8 


> Wy ls RE 


图 7-53 在 页 面 插入 绑 定 字段 
在 本 页 面 中 添加 两 个 隐藏 区 域 , 一 个 为 redate, 用 来 设 定 回复 时 间 ，, 赋值 等 于 <?php 
date_default_timezone_set('Asia/Shanghai):echo date("Y-m-d h:i:s");2>， 另 外 一 个 是 passid， 
用 来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 就 自动 通过 审核 ， 如 图 7-54 所 示 。 


属性 


加 = 
redate 值 ) lai );echo date CY-m-d hi:s"):?"| 多 


属性 
隐 划 区 域 
回 i 值 o) 0 你 
图 7-54 设置 “隐藏 区 域 ”两 个 字段 的 属性 
单 击 “ 服 务 器 行为 ”面板 上 的 辆 按钮 ， 在 弹出 的 菜单 中 选择 “更 新 记录 ” 命 
如 图 7-55 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 。 
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在 打开 的 “更 新 记录 ”对 话 框 中 ， 如 图 7-56 所 示 进行 更 新 设置 。 


出 | 


显示 记录 计数 
2 
插入 记录 
二 除 记录 

动态 表单 元 素 入 
用 户 身份 验证 (2 
hs i DB 
编辑 报 务 器 行为 .、 


| 新建 报 务 器 行为 
所 次 取 更 多 服务 器 行为 ，， 


图 7-55 选择 “更 新 记录 ”命令 图 7-56 设置 “更 新 记录 ”对 话 框 
国 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 这 样 就 完成 回复 留言 页 面 的 设置。 
和 多 7.4.4) 删 除 留 言 页 面 


删除 留言 页 面 delbook.php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 ， 页 面 设 
计 效 果 如 图 7-57 所 示 ， 详 细 说 明 步 骤 如 下 。 


配 rr 二 征 HaE 奋 二 一 并 le i 
图 7-57 删除 留言 页 面 效果 图 
打开 delbook.php 页 面 ， 单 击 “ 绑 定 ”面板 上 的 图 按钮 ， 在 弹出 的 下 拉 菜 单 中 ， 选 
择 “ 记 录 集 (查询 ) ”选项 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 : 
@ 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 gbook。 
@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
© 
二 


在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
设置 “筛选 ”的 方法 为 : ID =URL 参 数 /ID。 
单 击 “ 确 定 ” 按 钮 完成 设 定 ， 如 图 7-58 所 示 。 
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( N6 


出 


图 7-58 设置 绑 定 的 “记录 集 “ 


辆 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 delbook.php 网 页 的 各 说 明文 字 后 面 ， 如 
图 7-59 所 示 。 


二 cymnppwhdecnqbooteuabcorpm = 
MY hock po hd 


My Wy de i le 


图 7-59 字段 的 绑 定 
在 delbook.php 的 页 面 上 ， 单 击 “ 服 务 器 行为 ”面板 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 
单 中 选择 “删除 记录 ”命令 ， 如 图 7-60 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删除 操作 。 
在 打开 的 “删除 记录 ”对 话 框 中 进行 设置 ， 如 图 7-61 所 示 。 


图 7-60 选择 “删除 记录 ”命令 图 7-61 “删除 记录 ”对 话 框 
辆 单 击 “确定 ”按钮 回 到 编辑 页 面 后 ， 这 样 就 完成 删除 留言 页 面 的 设置 。 
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第 7 章 全程 实 例 五 ， 留 言 簿 管理 系统 


2 7.5 ”留言 簿 系统 测试 

留言 簿 系统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 到 了 留 
言 者 的 下 采集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 要 测试 留言 功能 的 执行 情况 。 
< 入 7651) 前 台 留言 测试 

具体 的 前 台 测 试 步 又 如 下 : 


打开 IE 浏 览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/gbook/， 打 开 index.php 文 件 ， 如 图 
7-62 所 示 。 


四 名 首页 -此 界 之 下 3.5 本 -了 
| 
图 蕊 - 转 字 会 公主 | 虽 htpy1iz70oloboow -| A- | [an ra a 
时 自 
EE sak) 
4 加 
So ee 
Ca thd 
ox - *PHP 留 言 管 理 系 统 - > 
a | 
| 


Teer | 合 名 言 入 
0 0 果 从 有 什么 则 电 要 和 ti， 清香 去 医 六 结 匠 各 言 ， 我们 二 生 一 林 同 结 你 和 其 - 
记录 1 到 9030 

ID 号 入 高 主题 : 


日 来 自 的 朋友 在 廊 语 内 容 ; 于 | 
= 


过 天 。 对不起， 要 无间 揽 1 


六 用 新 用 户 拆 加 守 友 


二 和 
3! 
. ba 
ED [ET 
图 7-62 首页 效果 
网 单 击 “ 留 言 ” 超 链接 ， 就 可 以 进入 留言 页 面 book.php， 如 图 7-63 所 示 。 
Ou tn235 Fw EX 
'g - 鲜 字 会 和 竟 | 中 htpl2700Uobooxsboocphp -| [A | | 二 必 和 Qa] 


上 | | 
EECFTIEYC23 


图 7-63 留言 页 面 效果 图 
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园 开始 检测 留言 簿 功能 ， 在 “留言 主题 ” 栏 中 填写 “测试 留言 主题 ”， 在 “留言 内 


容 ” 栏 中 填写 “测试 留言 的 内 容 ”。 填 写 完 后 ， 单 击 “ 提 交 ” 按 钮 ， 此 时 打开 indexphp 页 
面 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 图 7-64 所 示 。 


个 久 言 首页 -世界 之 窗 3.5 


PP-@ 儿 会 人 9 请 |Dmp//127.00.1ybominie 


hie hua dl 


0 了 .FHP 名 言 站 遂 妆 所 a 
ss 


现在 时 本 是 : 2012-05-9 0343.06 


加 果 你 有 什么 问题 看 要 咨询 的 话 ， 请 单 击 留 言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答复 , 
记录 1 到 1(8 共 
谢 式 上 言 主题 
来 自 127004 的 朋友 在 留言 内 容 : 
测试 日 言 的 内 容 
对 不 超 ， 特 无 回 夏 ? 


| 


加 
TG A100%- 


图 7-64 向 数据 表 中 添加 的 数据 


管理 测试 


台 管 理 在 留言 短 管 理 系 统 中 起 着 很 重要 的 作用 ， 制 作 完成 后 也 要 进行 测试 ， 操 作 步 
又 如 下 : 
贺 打开 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/gbook/admin_login.php ， 打开 
admin_login.php 文 件 ， 如 图 7-65 所 示 。 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 中 ， 输 入 用 户 
及 密码 ， 输 入 完毕 后 单 击 “ 登 录 ” 按 钮 。 


入 后 S 符 介 -世界 之 窗 3 Eee 


司 忆 -四 字 会 色 瘟 | 口 htp:/127.001/ebooMadmin_ bgnphp -| 中 六 -| [二 .证 让 3 Q 
思 关外 接 > 
uesss | Ca 
留言 板 管理 系统 后 各 登录 | 
用 户 ， 
密码 ， 
EE[E 


(38.83, B16-320) 辣 且 易 介 加 中 司 100%- 


图 7-65 “后台 管理 入 口 
如 果 在 上 一 步 中 填写 的 登录 信息 是 错误 的 ， 则 浏览 器 就 会 转 到 主页 面 index.php; 
如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin.php 页 面 ， 如 图 7-66 所 示 。 
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二 后台 管理 -世界 之 窗 3.5 
a 


-图 多 会 仿 究 [@nip://12700.Vobookaomnpnp -| 中 | [Mv | [本 全 3 


思 加 外接 


有 让 
a ett 
丛生 : 管理 主页 面 

| 
伟 sep,: | 
编号 。 主题 内 容 i 人 
2 训 二 全 言 主 二 生计 的 内 容 127001 副 除 加 所 


| (13883, 780.423) 


四 | 
| | 
关上 且 易 F 划 因 币 屿 100% 


图 7-66 ”打开 的 留言 管理 页 面 
单 击 “ 删 除 ” 超 链接 ， 进 入 删除 页 面 delbook.php， 并 自动 将 该 留言 信息 删除 。 删 
除 留言 后 返回 留言 管理 页 面 admin.php。 


Os -R25 


在 留言 管理 页 面 单 击 “ 回 复 ” 超 链接 ， 则 进入 回复 页 面 reply.php， 如 图 7-67 所 示 。 


本 已: 量 多 会 私 议 |Drrr 


-ox 

127.001 IN » | A- [tg, Sez al 

9 te S 
9 
a 


人 的 内 站 


i 

Nar oe 

二 由 六 

认 尖 合作 


Ess 


属 
GREYSTTTH DE 


图 7-67 打开 的 回复 页 面 
当 填 写 回复 内 容 “ 回 复 测试 ”， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回复 留言 。 


本 实例 制作 的 留言 簿 管理 系统 在 功能 上 相对 还 是 比较 简单 的 ， 读 者 如 果 在 实际 开发 中 
需要 进行 深入 地 开发 ， 可 以 在 此 基础 上 做 一 些 变化 ， 使 制作 的 留言 短 能 够 更 为 人 性 化 些 。 
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第 章 


全 程 实例 六 : 网 站 论坛 管理 系统 


论坛 管理 系统 的 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 
通过 Internet 来 进行 连接 ， 执 行 用 户 消息 之 间 的 交互 功能 ; 支持 用 户 建 贴 、 回 复 、 搜 索 、 
查看 等 功能 。 本 章 将 学 习 使 用 PHP 语 言 实现 论坛 管理 系统 的 开发 方法 ， 主 要 设计 网 站 论坛 
管理 系统 的 首页 ,用户 可 以 在 这 里 发 布 讨论 的 主题 ， 并且 也 可 以 回复 主题 ， 版 主 可 以 对 自 
己 的 栏目 或 版 块 进行 新 增 、 修 改 或 者 删除 等 操作 。 


@ 论坛 管理 系统 的 规划 设计 

@ ”建立 论坛 管理 系统 的 数据 库 

@ 新 增 主题 、 删 除 主题 、 回 复 主 题 的 实现 方法 
@ 论坛 系统 后 台 管理 功能 的 开发 


2 8.1 论坛 管理 系统 的 规划 

论坛 管理 系统 是 基于 各 大 网 站 对 论坛 的 建设 和 管理 需求 而 建立 的 交互 系统 ， 主 要 实现 
管理 员 对 论坛 版 块 、 贴 子 管理 ; 论坛 管理 系统 的 开发 是 比较 复杂 的 ， 需 要 经 过 前 期 的 系统 
规划 。 


87T1 页 面 设计 规划 


在 本 地 站 点 上 建立 站 点 文件 夹 bbs， 将 要 制作 的 系统 文件 如 图 8-1 所 示 。 


各 口 "， * 计算 由 ，Acer (Cj ， xampp » htdocs » bbs » 四 加 | 医 
tor 
组 织 ” 。 包 全 到 志 中 ” 。 共享 ” 刻录。 新 建文 件 闪 
二 上 收藏 夫 BD_mmServerScripts 
Bh creetive cloud 
让 
到 点 本 adminphp 日 
记 遇 # 广 989 和 一 [bbs_addphp 目 
Lcentent php | 
二 应 Ddelreplyphp Ddeltite.php 
国 视 机 Dindex.php Dupd.tye.php 
图 图 片 
让 
| 16 个 对 象 


图 8-1 站 点 规划 文件 
本 章 要 开发 的 BBS 论坛 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 所 示 。 
表 8-1 BBS 论坛 系统 网 页 设计 表 
页 面 名 称 功能 


indexphp 
主要 显示 讨论 主题 的 回复 内 容 页 面 

bbs_ addphp 
admin_login php 
admin php 
del ie php 
del reply php 


< 多 8.1.2 ) 设 计 页 面 美工 
论坛 系统 的 界面 要 求 简洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 提高 论 
坛 的 加 载 速度 。 这 里 要 制作 的 首页 和 详细 内 容 页 面 效果 如 图 8-2 和 图 8-3 所 示 。 
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[ER RE 

所 | 好 会 | 太 图 mitp:1127.0.0LE dex.php BEvY 

LC es x EE 
PHP 论 坛 管理 系统 。 “| 论坛 上 页 | 发 表 主题 “| 回复 主题 | 后 训 管 理 


护 


图 8-2 首页 的 美工 效果 


EE BW 
| 三 会 六 | 加 mep/f27001 pnt ev 
| EP 
PHP 论 坛 管理 系统 。 | 兴 s#N | 发 主题 | 网 复 主题 ”| 后 台 管 理 ] 

nd 


TE Bon 
员 a ean | 
A wim DF FY O30 | 


图 8-3 ”详细 内 容 页 面 效果 
2 8.2 论坛 管理 系统 数据 库 


制作 论坛 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 定 ， 这 里 要 设计 用 于 讨论 主题 的 信 
息 表 bbs_main， 用 于 回复 内 容 的 信息 表 bbs_ref， 最 后 还 需要 建立 一 个 管理 员 进 行 管理 的 信 
息 表 admin。 


< 521 数据 库 设计 
首先 建立 一 个 bbs 数 据 库 ， 并 在 里 面 建立 管理 员 管 理 信 息 表 admin、 讨 论 主题 信息 表 
bbs_main 和 回复 主题 信息 表 bbs_ref， 这 三 个 数据 表 作 为 任何 数据 的 查询 、 新 增 、 修 改 与 删 


除 的 后 端 支持 。 
制作 的 步骤 如 下 : 


加 在 phpmyAdmin 中 建立 数据 库 bbs， 单 击 SsB 认 命令， 打开 本 地 的 “数据 库 ” 管理 页 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 bbs， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 
框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general ci 选项 ， 单 击 “ 创 建 ”按钮 ， 返回 “常规 设置 ” 
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页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 bbs 的 数据 库 ， 如 图 8-4 所 示 。 


后 全 外 六 | 加 Pa27001 [2 


phpMyAdm EE 
OU. a 
ER 


图 8-4 开始 建立 数据 库 


贺 单 击 左边 的 bbs 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
admin、bbs_main 以 及 bbs_ref， 即 创建 3 个 数据 表 ， 如 图 8-5 所 示 。 


人 DO /27001 ee 


We 全 PBS 本 


ELL 


Ft 


图 8-5 创建 3 个 数据 表 


国 bbs_main 是 用 于 存储 论坛 的 主题 表 , 输入 数据 名 并 设置 相关 数据 ( 如 图 8-6 所 示 ) ， 
对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 bbs_main 的 字段 结构 如 表 8-2 所 示 。 
表 8-2 讨论 主题 信息 表 bbs_main 
字段 名 称 数据 类 型 字段 大 小 
| bsm | NTeGER 
| bbstime | 


[wns Tm 
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号 ee 


[Bs 


ji¢ 瑟 | 合 | 雪 加 1270.01 = BEv 


计 127001/17001/bbs 


phpMyAdmin 
8 A 局 SA MM -ES 
_ 国 是 衬 sw mt 要 作 
TT AUTO INCREMENT 7 BN © MS TE 
2 bos te varchar20) um goal dl EN OM ves 
目 3 bbe contokt we vl oneml dl FR Os ms 
sr 0 EN OM v3 
al 间 A OQ lt “es 
和 0 2 i 
ember a Er OM es 
wa [a | 


varhar20) um gneral. eh © WN va 


ON 


nn 


已 和 FEN DN 六 面 8- 吾 币 引 


和 


I 


5 同 5 


图 8-6 bbs_main 数据 表 


加 回复 主题 信息 表 bbs_ref 字 段 采 用 如 表 8-3 所 示 的 结构 。 设 计 后 的 数据 表 如 图 8-7 所 示 。 
表 8-3 ”回复 主题 信息 表 bbs_ref 


字段 名 称 数据 类 型 


VARCHAR 


Pr CORE 
{| 全 会 丰 | 园 127.0.0.1 BEvY 
pez 
phpMyAdmin 
One 3 A 和 局 导 A 仿生 人 更 和 
[EL] 加 下 名 宁 E73 nn 所 作 
局- bbs | bbs_main iD TD) 天 Im OM vd 
Fa 记 > bb mw) 普天 AUTOUNCREVBT il Smt 开 | 
bbs_ret 可 > li DMN 更 : 
| Tre § oi OM vr: 
B39 goook 
riormeton_ acheme 要 es OM ve 
eber 7 bbe et wt one Ff OM ve 
Fs mq EE bbe ref ome varchar20) us eenersl of 2 Ss OW “ee 
etter t_ 2 27 EN FE 0 全 六 耐 疙 ~ 国人 过 引 
全 pnpmyadn 
订 pnpven 
让 了 ea ET 四] 
耳 各 为 人 地 全 硬 于 示 共 导 局 [ 执 可 
应 wobaun 
Ek = 下 


8-7 bbs_ref 数据 表 


加 最 后 设计 用 于 后 台 登 录 管 理 的 admin 数 据 表 ， 字 段 采 用 如 表 8-4 所 示 的 结构 。 设计 
后 的 数据 表 如 图 8-8 所 示 。 
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表 8-4 ”管理 员 管理 信息 表 admin 


字段 名 称 数据 类 型 字段 大 小 


Ip | mreoer 


VARCHAR 
VARCHAR 


EE x 
€ Ox|@ 127001 EF 
EE 01117001 bo > 国 因 和 B+ 
phpMyAdmin “| -REEEEICEEESDIEEXDD 国 - 
-ys 目的 和 So A 和 A 三 5 加 SA FM -es | 
EI 国 六 名 。 交 弄 其 这 生 则 属性 空 对 认 本 外 机 人 
到 AUTO_INCREMENT ,从 坟 加 出 机 
hy ft OM 
-局 杏 EC 
dmin 从 日 Mv 
及 二 bs mi 
由 三 ba_rf > 让 呈 国 时 - 同系 引 
机 1 ca 
帅 G sbook 
南 1 npmation shem 本 
记 - member | EE MS 
mg |+* 
市 rm 
机 peromance scnema 信息 
人 phpmadni 
ms 司 Row sadetes 
-二 括 30 守节 莉 式 
布 1 webaum 要 引 2K9 ee 
所 计 间 人 下 
全 长度 
有 大 小 
| 下 下 时 


图 8-8 后 台 管 理 admin 表 


国 数据 库 创建 完毕 后 , 在 后 台 管 理 数 据 表 admin 里 输入 用 户 名 和 密码 ,以 方便 后 面 登 
录 查 询 使 用 。 


-和 822 ) 论 坛 管理 系统 站 点 


在 Dreamweaver CC 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 主 要 的 设置 如 表 8-5 所 
示 。 
表 8-5 ”站 点 设置 的 基本 参数 


站 点 名 称 bbs 


MySQL 服 务 器 地 址 | C:xampp\mysql\data\bbs 


管理 账号 / 密码 root / 空 
数据 库 名称 bbs 


创建 bbs 站 点 具体 操作 步骤 如 下 : 


加 首先 在 C:xampp\htdocs 路 径 下 (如 图 8-9 所 示 ) 建立 bbs 文 件 夹 ， 本 章 所 有 建立 的 网 
页 文件 都 将 放 在 该 文件 夹 下 。 
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运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 


理 站 点 ”对 话 框 ， 如 图 8-10 所 示 。 


对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 bbs” 对 话 框 ， 进 行 如 图 8-11 所 示 的 参数 设置 。 
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Ee 
SO" tan ，AcerC » ampp » hdors » 7[4|| a hedocs 万 
文件 ”往生 (日 可 看 V) 工具 才 动 H) 
组 R” 忆 J 开 ah” #” iH ~ © 
可 PE “站 indexphp xampp BmmServerScripts 
司 图 片 Dindexhtml ve 
国 北 回 favicenico 下 restrided 
总 inami 
中 二 
pe 引 spache pbzpng 是 ims 
甘 apache_pb2gif 。。 明 gbook 
色 Aeer Eapache pb.png 上 forbidden 
a MD) 天 specbe pbeif FT 
EE 
bbs 人 x 日 敬 2014/12/10 848 
只 x 


图 8-9 建立 站 点 文件 夹 bbs 


图 8-10 “管理 站 点 ”对 话 框 


a preomacove 让 点 是 网 站 中 使 用 的 所 有 文件 和 次 的 后 。Dreomweaer 
ENE ws 向 
意 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夫 和 名 称 。 
让 点 名 称 : [bbs 
二 地 让 六 件 赤 : [CiVanco haocs bosl 国 
E23 入 ][ 陋 


图 8-11 建立 bbs 站 点 
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单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 包 ， 打 开 “ 基 本 ” 
选项 卡 进行 如 图 8-12 所 示 的 参数 设置 。 


图 8-12 设置 “基本 ”选项 卡 
设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 同步 
信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL， 表 示 是 使 用 PHP 开 发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 8-13 所 示 。 


图 8-13 设置 “高 级 ”选项 卡 


单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 复 选 框 ， 如 图 8-14 
所 示 。 


二 


- 一 | 您 将 在 此 位 置 选择 承载 Web | 此 对 话 框 的 设置 来 自 
zy | Intemet 腿 务 提供 商 (IsP) 或 Web 管理 员 ， 


em re 人 下 


区 EE 
bs Rs | 


图 8-14 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 
刚才 所 设置 的 站 点 bbs。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CC 测试 网 站 论坛 管理 系统 网 页 的 环境 设置 。 


< 523 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 需 要 在 用 户 系统 网 站 与 数据 库 之 间 设 置 连接 ， 网 站 与 数据 库 的 
连接 设置 如 下 : 


贺 将 设计 的 本 章 文件 复制 到 站 点 文件 夹 下 , 打开 index.php 论 坛 系统 的 首页 , 如 图 8-15 
所 示 。 


二 三 


Yu Fe 


图 8-15 打开 网 站 首页 
单 击 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命令， 打开 “数据库” 面板 。 在 该 面板 上 
单 击 “+” 图标， 在 弹出 的 下 拉 菜 单 中 选择 “MySQL 连接 ”选项 ， 如 图 8-16 所 示 。 
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1 
: 

Y ”3. 设置 站 点 的 
4 


单 击 上 面 的 + 按钮 创建 连接 。 


图 8-16 选择 MySQL 连接 
在 “MySQL 连接 ”对 话 框 中 输入 “连接 名 称 ” 为 bbs、“MySQL 服 务 器 ”名 为 
localhost、 “用 户 名 ”为 root、“ 密 码 ” 为 admin。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 
单 击 “ 选 取 ” 按 钮 浏览 MySQL 服 务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 bbs， 具 
体 的 设置 内 容 如 图 8-17 所 示 。 


MySQL 服务 器 : 1ocalhost 
用 户 名 : root 
密码 : 
数据 库 : bbs 


图 8-17 设置 MySQL 连接 参数 。 
加 单 击 “ 测 试 ” 按 钮 测试 与 MySQL 数 据 库 的 连接 是 否 正确 ， 如 果 正 确 则 弹出 一 个 提 
示 消 息 框 (如 图 8-18 所 示 ) ， 这 表示 数据 库 连 接 设置 成 功 了 。 
贺 单 击 “ 确 定 ” 按 钮 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 8-19 所 示 。 


bbs_eontent (text) 
Bh bbs_enail (varcher ¢ 
bbs_face (warchar 2 


二 央 二 由 由 中 下 由 


四 -图 bos_ref 


四 -如 视图 
四 -长 ”预存 过 程 
< > 
图 8-18 设置 成 功 图 8-19 绑 定 的 数据 库 


2 8.3 论坛 系统 主页 面 


在 Dreamweaver 中 定义 站 点 ， 建 立 数据 库 连 接 后 ， 就 可 以 进入 PHP 页 面 的 设计 阶段 ， 
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首先 制作 最 重要 的 首页 index.php，index.php 页 面 主要 显示 所 有 的 讨论 主题 和 最 新 回复 的 一 
些 信息 。 


论坛 系统 的 主页 面 index.php 显 示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复数 以 及 最 
新 回复 时 间 。 访 问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 理 ” 图 标 进 
入 管理 页 面 ， 系 统 主 页 面 index.php 的 静态 页 面 设计 如 图 8-20 所 示 。 


动 coomppVndocsbbsindex php" -Ox 
WY br he hd 


PHP 论 坛 管理 系统 。 “| 论坛 首页 | 发 表 主题 | 回复 主题 | 后 各 管理 


Capyright @ 2012 www hbealeurw cea Inc. D1 raghee rarorved, FEFEEE 管 理 绕 


> si we 


图 8-20 ”BBS 论坛 系统 主页 面 静态 设计 效果 图 
详细 的 操作 步骤 如 下 : 


单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 因 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “ 记 
录 集 ( 查询) ”选项 ， 弹 出 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 : 


@ 在 “名 称 ”文本 框 中 输入 rs_bbs 作 为 该 记录 集 的 名 称 。 
@ 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连 接 对 象 bbs。 
@ 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 bbs_main。 
@ 在 “ 列 ” 栏 中 选中 “全 部 ” 单 选 按钮 。 
完成 的 设置 情况 如 图 8-21 所 示 。 
记录 入 
名 称 : rs_bbs | 证 | 
我 格 : [Ra = L_ Ra] 
下 加 全 部 和 证 的 Ee 
EE 


下 | 升序 


图 8-21 “记录 集 ” 对 话 框 
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加 再 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语法 改 成 以 下 
的 SQL 语法 ， 如 图 8-22 所 示 。 


MB, 


. SELECT 
. bbs Main.bbs_ID, 


bbs Main.bbs Time, bbs Main.bbs Hits 

bbs Main.bbs Title, bbs Main.bbs url, 

bbs Main.bbs email, bbs Main.bbs sex, 

bbs Main.bbs Face, bbs Main.bbs Content, 

bbs Main.bbs Name,COUNT (bbs Ref.bbs Main ID) AS ReturnNum, 


. MAX (bbs Ref.bbs ref Time) AS LatesTime 
. FROM 

. bbs Main LEFT OUTER JOIN bbs Ref ON 

. bbs Main.bbs_ID=bbs Ref.bbs Main_ID 

. GROUP BY bbs_ Main.bbs_ID 


图 8-22 改写 SQL 语句 


Bbs_ref 数 据 表 中 的 记录 可 以 通过 bbs_main_ID 字 段 关 联 到 bbs_main 数 据 表 中 的 bbs_ID 字 段 。 因 
为 bbs_ref 数 据 中 对 应 的 数据 表 可 能 不 存在 ，bbs_main 数 据 表 并 非 一 定 有 对 应 回复 的 话题 。 所 
以 LEFT OUTER JOIN 将 接合 关系 中 的 两 个 数据 表 分 成 左右 两 个 数据 表 ， 其 中 左边 数据 表 在 经 
过 接合 后 ， 不 管 右边 数据 表 是 否 存 在 ， 仍 然 会 将 资料 全 部 列 出 。 简 单 地 说 ， 就 是 不 管 讨 论 主 
题 bbs_main 是 耕 有 任何 的 回复 bbs_ref， 使 用 LEFT OUTER JOIN 可 以 将 数据 表 bbs_main 中 的 所 
有 讨论 主题 都 显示 出 来 。 

另外 ，GROUP BY 语句 是 针对 bbs_main 数 据 表 中 的 bbs_ID 字 段 ， 在 第 2 行 到 第 6 行 之 间 的 意思 就 
是 说 取出 bbs_main 数 据 表 中 的 特定 字段 内 容 。 同 时 将 bbs_ref 中 的 关联 取出 ， 获 得 bbs_time 和 
bbs_ID 的 两 个 字段 内 容 。bbs_ref time 字 段 取 所 有 记录 当中 时 间 最 新 回复 的 那 一 条 用 来 显示 。 而 
bbs_ ID 字段 则 用 COUNT 计 算 有 多 少 人 回复 的 数目 。 


加 绑 定 记录 集 后 ， 将 绑 定 字段 插入 至 index.php 网 页 中 的 适当 位 置 ， 如 图 8-23 所 示 。 
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| 前 cvamppwndocs\bbs\inder php” -Cx 
hs. php 


: PHP 论 坛 管理 系统 。“ | 论坛 首页 | 发 表 主题 | 回复 主题 “| 后 台 管理 


ET nl i on pr a 
发 言 主 是 作者 i 弛 可 加 让 ls Ee 


| 
rs hos bsTitnl 
! 


[KI Wa tue © a We YW [TD mw 
图 8-23” 绑 定 字段 的 插入 

辆 插入 字段 后 把 光标 放 入 到 “心情 ”下 面 的 单元 格 里 ， 然 后 再 执行 菜单 栏 “ 插 入 ” 

人 一“ 图像” 命令， 打开 “图 像 ”对 话 框 任意 插 入 一 张 图 片 ， 然 后 在 “属性 ”面板 中 设置 Scr 
( 源 ) 为 空 ， 如 图 8-24 所 示 。 单 击 “ 确 定 ” 按 钮 ， 插 入 一 个 图 像 占 位 符 。 


上 日 国 ass 无 
GE 十 朋 本 


图 8-24 图 像 “ 占 位 符 ” 对 话 框 
设置 Scr ( 源 ) 文本 框 为 <?php echo Srow_rs_bbs['bbs_Face']; ?>， 表 示 调用 动态 的 
数据 值 ， 并 将 宽 和 高 的 值 清空 ， 如 图 8-25 所 示 。 


加 图 入 Sre TE 人 外 lesx 无 ~ 宽 人 0 px v 门 普 换 吕 ) 
| 蚀 接 中 Om MF PH HRON ol eS 
地 图 0) 目标 号 ) 


i 
3 DOr 原始 :| 
图 8-25 设置 动态 字段 
国 开始 进行 显示 区 域 的 设置 , 首先 选取 记录 集 有 数据 时 要 显示 的 数据 表格 , 如 图 8-26 
所 示 。 


心情 庄 是 法 


区 / {rs_bbs. bbs_Title} 


图 8-26 选择 要 显示 的 一 列 

单 击 “服务 器 行为 ”面板 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “显示 区 域 ”一 

“如 果 记 录 集 不 为 空 则 显示 区 域 ” 选项， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 中 ， 

单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 “如 果 符 
合 此 条 件 则 显示 ”字样 ， 这 表示 已 经 完成 设置 ， 如 图 8-27 所 示 。 
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DW ze mms EV 五 NM saiM no) sl0 wa SOW Ra 
Ea 


| 论坛 首页 | 发 表 主 是 


1 本 香 主题 ”| 后 台 管 理 


ee ee en ee ee ey 
任何 主题 


1 
Dj 所 7 -OW 
EE 


图 8-27 ”完成 显示 设置 


国 选择 没有 发 布 主题 数据 时 要 显示 的 文字 “目前 没有 发 表 任何 主题 ”， 根 据 前 面 的 
操作 方法 ， 将 区 域 设 定 成 “如 果 记录 集 为 空 则 显示 ”， 页 面 显示 如 图 8-28 所 示 。 


5 


二 cvamppwmdocrbbrvnderphp- 
bs pio 


”PHP 论 坛 管理 系统 。 “| 论坛 首页 | 发 表 主题 | 回复 主题 | 后 台 管理 


Tr mr pr 
时 可 回复 Hs 发 和 01 间 


frs_hts bhs-Time} 


rs pbs bts Hits} 


ERD wip ue 1 de WO MR JI ia [nm DO ev 
图 8-28 选择 没有 数据 时 的 显示 
国 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设置 ， 单 击 index.php 页 面 中 要 重复 的 记录 
列 ， 如 图 8-29 所 示 。 


让 {rs_bbs. bbs_Title} 
0 果 罕 合 此 条 件 则 吐 示 


图 8-29 选择 要 重复 显示 的 那 一 列 


单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 图 按钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ” 选 项 ， 在 打开 的 “重复 区 域 ”对 话 框 中 设置 显示 的 记录 数 为 20， 
如 图 8-30 所 示 。 

国 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 现 了 一 个 

“重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 当 记录 集 超过 一 页 ， 就 必须 要 有 “上 一 页 ”、 
“下 一 页 ”等 按钮 或 文字 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 导航 条 ”的 功 
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能 。“ 记 录 集 导航 条 ”按钮 位 于 “插入 ”工具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 
“常用 ”切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 分 页 ” 国 工 具 按 钮 ， 如 图 8-31 所 示 。 


BE 
ul 
E 


卉 " 折 AE 录 国 
图 8-30 选择 一 次 可 以 显示 的 次 数 图 8-31 选择 “记录 集 导航 条 ” 

在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 的 记录 集 并 设置 导航 条 的 显示 
方式 为 “文本 ”， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 
条 ， 如 图 8-32 所 示 。 

国 在 “讨论 主题 ”上 加 入 “ 转 到 详细 页 面 ”的 设置 。 用 来 显示 特定 主题 的 详细 内 容 
的 相关 的 回复 。 选 取 编 辑 页 面 中 的 rs_bbs.bbs_Title 字 段 ， 如 图 8-33 所 示 。 


EE 
bs pip 


PHP 论 坛 管理 系统 “| 论坛 首页 | 发 表 主题 “| 回复 主题 “| 后台 管理 


spbs bts J6 0) rs_bbs, bbs_Tima 


KD vi 本 Ye Wd GE 如 果 : 本 
图 8-32 添加 “记录 集 导航 条 ” 图 8-33 选择 字段 
在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 
话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 content.php， 设 置 如 图 8-34 所 示 。 
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图 8-34 选择 链接 文件 
单 击 “参数 ”按钮 ,设置 超 级 链接 要 附带 的 URL 参 数 的 名 称 与 值 
content.php?bbs_id=<?php echo S$row_rs_bbs["bbs_ID']; ?>。 将 参数 名 称 命名 为 bbs_id， 如 图 
8-35 所 示 。 


= 关 无 ~ BI 瘟 扫 汪汪 标题 0)[ 
”链接 中 ) Fontent php7bbs-idCophp echt v 加 加 目标 加 
i ~] 宽 0) | 不 换行 0) 门 ”背景 颜色 (G) 全 ,| 
[ 黑 认 ~] 高 咱 [ 40| ”标题 下) 站 
图 8-35 “参数 ”对 话 框 
单 击 “确定 ”按钮 完成 “ 转 到 详细 页 面 ” 的 设置 ， 在 index.php 页 面 中 有 两 个 连接 
按钮 “管理 ”与 “发 表 话题 ”， 设 定 其 链接 网 页 如 表 8-6 所 示 。 


表 8-6 ”按钮 链接 的 页 面 表 
按钮 名 称 链接 页 面 


< 83.3.2 ) 搜 索 主题 功能 


在 index.php 这 个 页 面 上 加 入 搜索 的 功能 ， 该 页 面 上 的 功能 设计 如 图 8-36 所 示 。 


Fas: [ 覃 向 ] 


图 8-36 搜索 主题 设计 


制作 步骤 如 下 : 
加 将 查询 主题 的 文本 框 命名 为 keyword， 设 置 如 图 8-37 所 示 。 


- 285 - 


Sale 网 站 开发 全 程 实例 (第 2 版 ) 


年 Ks ep 
BE | 
器 文本 城 于 笠 寅 度 加 加“] 类 型 四 单行 6) Og 行 ) 〇 过 吗 罗 关中 
ferrors | 最 多 字 答 数 | ”初始 入) | 7 
口音 用 史 ) 
口 A 玉 珈 


图 8-37 设置 keyword 文本 域名 


将 之 前 建立 的 记录 集 rs_bbs 作 一 些 更 改 ， 打 开 记 录 集 ， 并 进入 “高 级 ” 设 定 对 话 
框 。 在 原 有 的 SQL 语法 中 GROUP BY bbs_Main.bbs_ID 前 面 ， 加 入 一 段 查询 功能 的 语法 : 
where bbs Title like '%".$keyword."%" 


SQL 语 句 将 变 成 如 图 8-38 所 示 。 


Em 
fh Febbs Erm 
二 1 
这 接 [ps =] EY 
和 CM ] 
ors Er Tom To Ms ee on 症 | 
国 


SRP Bi bbs ur. bbs 


= 
| 用 


涩 扣 库 项 是 本 


图 8-38 修改 SQL 语句 
再 切换 到 代码 设计 窗口 。 在 rs_bbs 记 录 集 绑 定 的 代码 中 加 入 代码 : 
$keyword=$_POST [keyword]; // 定 义 keyword 为 表单 中 "keyword" 的 请 求 变量 


如 图 8-39 所 示 ， 完 成 设置 。 


"sthelorDefinedyatue = 


1f (PHP_VERSION < 6) { 
Value = get_ragic_quotes_apc() ? stril 


回 
全 


ES 


rm ? nevatsthevatue) : " 


图 8-39 加 入 代码 


贺 以 上 的 设置 完成 后 ,index.php 系 统 主页 面 就 有 查询 功能 了 , 可 以 按 下 F12 键 至 浏览 
器 测试 一 下 是 否 能 正确 的 查询 并 显示 。index.php 页 面 会 显示 所 有 网 站 中 的 讨论 主题 ， 如 图 
8-40 所 示 。 
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ER 。@® 


图 8-40 主页 面 浏览 效果 图 


供 访问 者 使 用 的 页 面 有 讨论 主题 页 面 contentphp 和 回复 讨论 页 面 bbs_reply.php， 下 面 
就 开始 这 两 个 页 面 的 制作 。 
< 54.1 ) 讨 论 主题 

讨论 主题 内 容 页 面 content.php 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 
主题 的 详细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-41 所 示 。 


8-41 讨论 主题 内 容 页 面 设计 效果 图 


详细 的 操作 步骤 如 下 : 

加 在 contentphp 这 个 页 面 中 ， 要 同时 显示 讨论 主题 与 回复 主题 的 内 容 ， 因 此 需要 把 
两 个 记录 集 进行 合并 ， 一 次 取得 这 两 个 数据 表 中 的 所 有 字段 ， 根 据 主题 页 面 传送 过 来 的 
URL 参 数 bbs_ID 进 行 第 选 。 

单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选 
择 “ 记 录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “ 高 级 ”按钮 ， 进 入 记录 
集 高 级 设 定 的 对 话 框 ， 将 现 有 的 SQL 语句 改 成 如 下 的 SQL 语句 ， 如 图 8-42 所 示 。 


01. SELECT 
02. bbs main.*,bbs ref.* 


- 287 - 


Rd @ 


oa No (第 2 版 ) 


03. FROM 

04. bbs main LEFT OUTER JOIN bbs_ ref ON bbs main.bbs_ID= 
bbs_ref.bbs main ID 

05. WHERE bbs main.bbs_ID ='".$bbs_ID." 


EE 


数据 库 项 - Ey nh 加 S| SQL 
a | 
| 
于 


图 8-42 改写 SQL 语句 


/BE 


同样 用 LEFT OUTER JOIN 关联 bbs_main 和 bbs_ref 中 的 字段 ， 取 得 两 个 数据 表 中 的 相关 数据 。 并 
且 用 WHERE 语句 ， 筛 选 bbs_main 数 据 表 中 的 bbs_ ID 字段 值 等 于 $bbs_ ID 变量 值 。 


上 图 中 设置 了 一 个 名 为 Sbbs_ID 的 变量 值 ， 即 是 首页 传递 过 来 的 参数 ， 因 此 在 该 页 
自动 生成 的 PHP 代 码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 
Sbbs_ID=strval($_GET['bbs id']); 


加 在 设 定 完 记 录 集 绑 定 后 ， 先 把 记录 集 detail 中 的 字段 插入 到 页 面 上 ， 再 分 别 插入 两 
个 图 像 占 位 符 ， 两 个 图 像 占 位 符 分 别 绑 定 发 布 人 性 别 形 象 bbs_sex 字 段 和 回复 人 性 别 形 象 
bbs_ref sex 字段 ， 其 结果 如 图 8-43 所 示 。 


evarppVedoc ncentent phpr -Ox 
Deis 


图 (Er: (octalbbs_ conicat) 
信 电 邮件 办 攻 5 Pmsz| 司 
岛 国有 RE torts sef eeetoeg 
从 (aaabba maaj 从 忆 了 部件 从 主页 
BEA: desde ref me) | 二 
EES TE - 
> Sy en a us a sms LE 


8-43 detail 中 的 字段 插入 
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选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “属性 ”面板 中 的 “链接 ”文本 
框 后面 的 “浏览 文件 ”按钮 国 ， 打 开 “选择 文件 ”对 话 框 ， 在 该 对 话 框 中 选中 “数据 源 ” 
单 选 按钮 ， 然 后 在 “ 域 ”列表 框 中 选择 “记录 集 (detail ) ”组 中 的 bbs_email 字 段 ， 并 且 在 
URL 链 接 前 面 加 上 “mailto:”， 如 图 8-44 所 示 。 


ES 
[ 格式 中 无 ~] 类 无 ~ BI 温 反 振 兰 标题 ID | 


> TAML| 
本 css mm) 无 < 负 四 wiitropip eeho fordeti > 加 四 目标 的 - 


引 | 单元 格 。 水 平 吕 | 默认 =] 宽 0) 不 摘 行 0) 门 背景 颜色 (6) [| srTFFTF Cr 
记 闪 ”要 直 中 | 冉 A -高 0 25 标题) 门 


图 8-44 设置 主题 栏 中 的 email 的 链接 
国 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “属性 ”面板 中 的 “链接 ”文本 框 后 面 的 
“浏览 文件 ”按钮 国 ， 打开“ 选择 文件 ”对 话 框 ， 在 该 对 话 框 中 选中 “数据 源 ” 单 选 按钮 ， 
然后 在 “ 域 ”列表 框 中 选择 “记录 集 ( detail ) ”组 中 的 bbs_url 字 段 ， 并 且 在 URL 链 接 前 面 
加 上 “http:/” ， 如 图 8-45 所 示 。 


~ BI 党 后 生 闪 标题 中 
”机 撞 们 http:// 人 php echo Sror_detai] v 回国 ”目标 名 - 


css 
a9 单元 格 。 水 平 C)| 默认 ”| 宽 拉 ) 不 换行 o) 门 背景 颜色 (5) [| #7FFFFF [CRE 
一 盖 交 看 直 中 由 A 7 高 人 9 55 标题 @) 门 


图 8-45 设置 主题 栏 中 的 url 链接 

用 第 5S、6 步 骤 中 的 方法 ， 设 置 回 复 主题 中 的 “电子 邮件 ”和 “主页 ”的 链接 。 一 
个 是 “记录 集 ( detail )” 中 的 bbs_ref email 字段, 另 一 个 是 “记录 集 (detail)” 中 的 bbs_ref URL 
字段 ， 如 图 8-46 和 8-47 所 示 。 
ee 
[| 要 式 中 污 v] 类 无 - BI 六 卉 竺 站 标题) 
[3 


IO 无 ” 锣 扩 9 detail[ bbs_ ref_email ]; ?> 回回 ”目标 @ - 


图 | 单元 格 。 水 平 必 ) | 默认 ”| 克拉 ) 不 换行 四 ) 四 背景 颜色 (6) [| 4FTTTTT 
一 证 光 要 下 中 卜 A | 高 0 355 标题 @) 门 


图 8-46 设置 回复 栏 中 的 email 的 链接 


《<>mmL| | 格式) | 无 了 类 无 ~ BI 冯 后 兰 兰 标题 D) 


bh Css DD) 无 ~ 树 挤 匀 ow_detsil[ bbs_ref_wl]; ?> ~ 回国 ”目标 多 py 
Ea| 水 平 吕 [点 认 | 宽 ) | 不 换行 o) 四 ”背景 六 名 (6) [| srF7F7F | 
一 辣 次 委 直 上 | 默认 | 高 0| 25 ”标题 2) 门 


图 8-47 设置 回复 栏 中 的 url 链接 
国 单 去 “确定 ”按钮 ， 完 成 数据 源 的 绑 定 设置 ， 在 contentphp 页 面 中 有 两 个 链接 图 
示 “管理 ” 与 “发 表 话 题 ”， 必 须 设 定 其 链接 网 页 ， 如 表 8-7 所 示 。 


表 8-7 ”按钮 与 链接 页 面 表 
按钮 名 称 链接 页 面 
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国 选择 文字 “回复 主题 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 
文件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 bbs_reply.php， 设 置 如 
图 8-48 所 示 。 


= 
卡 ， 计 萤 册 》Acer (C] ，xampp » htdocs » bbs ， 加 E73 站 
名 只” 六 于 XH 六” 日 @ 
a 国 LE 类 大 小 四 
有 creatve closd 县 _mmsenerscrpts 2014/12110 1003 。 文 4 闪 
属 Tf 芝 notes 2014/12/10 848 。 文人 
PE comecticns 2014/12/10 B48 | 
是 同方 月 的 他 各 Bdate 2014/12/10 848 Ml 
Bimages 2014/12/10 848 nl 
|| 周 库 点 wn 2014/12/10 B48 
i 目 sdninpho PHP 文 伯 11k8 
可 Dadmin login.php PHP 文件 5KB 
国 bbs.addiphp PHP 文 件 oke 国 
国 邓 -en php 六 人 ae 
闻 BF 曲 comentphp 25 php 文件 11KB 
中 和 delrefptp 2012/577 1625 PHP 文件 4kB 
这 有 Re i 
文 HE(N): ~ [WiC 


图 848 选择 链接 文件 


单 击 “ 参 数 ” 按 钮 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 
bbs_reply.php?bbs_ID=<?php echo $row_detail['bbs_ID']; ?>。 将 参数 名 称 命名 为 bbs ID， 设 
置 如 图 8-49 所 示 。 


格式 F) [无 一 类 无 -BI 浑 提 站 当权 四 [ |] 
D0) 无 - ”链接 员 ho $row_detail[ bbs 0]; ?> ~ 加 目标 @) 四 


La 


口交 可 直 史 )| 


下 “5 水 平 加 [区 这 席 o)| 不 换行 o) 口 。 背 景 颜色 (G) 三 | # 
5 


高 | 25| 标题 中 辣 
图 8-49 “参数 ”对 话 框 
轩 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设 定 ， 单 击 content.php 页 面 中 要 重复 的 表 
格 ， 如 图 8-50 所 示 。 


加 


加 各 人 : (aaatlbbe_mf hme) 回复 内 容 : (dataltbe me eatead) 


ET 
图 8-50 选择 要 重复 的 表格 


单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”标签 上 的 固 按 钮 ， 在 弹出 的 下 拉 
菜单 中 选择 “重复 区 域 ”选项 ， 在 打开 “重复 区 域 ”对 话 框 中 设置 显示 的 记录 数 为 5 条 记 
录 ， 如 图 8-51 所 示 。 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 的 区 域 左上 角 出 
现 了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
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四 851 选择 一 次 可 以 显示 的 记录 数 
插入 “记录 集 导 航 条 ”功能 ， 单 击 国 工 具 按 钮 ， 在 打开 的 “记录 和 集 导航 条 ”对 话 


框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 ， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 
面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 8-52 所 示 。 

曾 cvamppwntdocaebsvcartentphe 加 

i cot 


i Dm 


bre 


国 
名 [i 


3》 (arabbe En) 区 电 于 绚 加 主页 
HA: (eed ses met pa) 


i 


retbeuirure com ne AL ogtas marred PE 论坛 笃 理 所 近 


[> Wy le WW CEM 


图 8.52 添加 “记录 集 导航 条 ” 
选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-53 所 示 。 


上 全 人 : (tite me name] | 回复 容 :taaltbt_nf pmrtemt) 


| 司 (thte ra 写作 的 主机 
图 8-53 ”选择 要 显示 的 一 行 
单 击 “服务 器 行为 ”面板 上 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “显示 区 域 ”一 
“如 果 记 录 集 不 为 空 则 显示 区 域 ” 选项， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 ”对 话 框 中 ， 
单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左上 角 出 现 了 一 个 “如 
果 符 合 此 条 件 则 显示 …?” 的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 如 图 8-54 所 示 。 


重复 
名 果 符 合 此 条 件 刚 旦 示 


内 容 : fdetallbbs_ref content} 


这 fdetalbbe zf tme} 大 电子 邮件 各 主页 


图 8-54 ”完成 设置 后 的 效果 
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ID 


“@? 必 人 


选择 没有 回复 数据 时 要 显示 的 文字 “目前 没有 回复 ”， 根 据 前 面 的 步骤 ， 将 下 面 
a 受 定 成 “如 果 记 录 集 为 空 则 显示 区 域 ”， 如 图 8-55 所 示 。 


回复 人 : 内 容 : 《detailbbs_yef content} 
{detail bbs_ref name} 


| 四 {etalbbs rf time}) 要 电子 邮件 多 主页 
目测 没有 间 
图 8-55 ”选择 没有 数据 时 的 显示 


< 342 设置 访问 

在 BBS 论坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 ， 当 访问 者 点 击 标题 进入 查看 内 容 
时 ， 阅 读 统 计数 目 就 要 增加 一 次 。 其 主要 的 方法 是 更 新 数据 表 bbs_main 里 的 bbs_hits 字 段 来 
实现 。 

详细 操作 步骤 如 下 : 

加 实现 的 方法 很 简单 ， 打 开 content.php 页 面 ， 在 代码 的 第 50 行 加 入 一 行 更 新 的 SQL 
语句 : 

mysql_query("UPDRATE bbs_main SET bbs hits = bbs hits + 1 WHERE bbs_ID 
= '".$bbs ID."'"); 

代码 说 明 如 下 : 


01.UPDATE bbs_main  // 更 新 bbs_main 数 据 表 
02.SET bbs_ hits = bbs_hits+1 // 设 置 bbs_main 数 据 表 中 的 bbs_hits 中 字段 自动 加 1 
03 .WHERE bbs_ID = '".$bbs_ID."' ”// bbs_ID 的 值 等 于 $bbs_ID 变 量 中 的 值 


园 加 入 的 代码 位 置 如 图 8-56 所 示 。 


国 cvameewedocnpbeoreertphp -Ox% 
CE 恒 
外 


有 


烛 
3 
着 | 
外 


ET 


图 8-56 ”代码 加 入 的 位 置 
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多 8.43 ) 新 增 讨论 
新 增 讨论 主题 页 面 bbs_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs_main 数 
据 表 中 ， 页 面 设计 如 图 8-57 所 示 。 


动 cyamppVndocs\bbs\bbs addphp- SE 


PHP 论 坛 置 理 系 统 。 “| 论坛 首页 | 发 表 主题 | 回复 主题 | 后 台 管理 


Wy sy ble We fen tiel 目 目 TTIES 


图 8-57 ”新 增 讨论 主题 页 面 效果 图 
详细 操作 步骤 如 下 : 


加 在 bbs add.php 页 面 设计 中 ， 表 单 form1 中 文本 域 和 文本 区 域 设 置 如 表 8-8 所 示 。 
里 要 注意 “性 别 形象 ”和 “心情 ”的 单 选 按钮 都 要 在 属性 面板 中 定义 其 值 。 


表 8-8 ”表单 form1 中 的 文本 域 和 文本 区 域 设置 方法 表 
文本 〈 区 ) 域 /按钮 名 称 方法 /类 型 


[oie | 
[bssee ga | 


记 


单行 
[bs | | 


[gl| <2php date_default_timezone_set('Asia/Shanghai); 
echo date("Y-m-d");?> 获 取 提 交 时 的 时 间 
[bsnis | 


bbs_hits 初始 值 为 0 
| suomit | 提交 表 单 
重 设 表单 

贺 在 bbs_add.php 编 辑 页 面 ， 单 击 “ 服 务 器 行为 ”面板 标签 上 的 国 按钮 ， 在 弹出 的 下 
拉 菜 单 中 选择 “插入 记录 ”选项 ， 在 “插入 记录 ”的 设 定 对 话 框 中 设置 如 下 : 

@ 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作 为 数据 源 连 接 对 象 。 

@ 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs_main 作 为 使 用 的 数据 库 表 对 象 。 
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名 Se 


@ 在 “插入 后 , 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_main, 然后 再 转 到 index.php 
网 页 。 

@ 在 “ 列 ” 列 表 框 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs_main 中 的 字段 一 一 对 

设置 完成 后 该 对 话 框 如 图 8-58 所 示 。 

选择 表单 ， 执 行 菜单 栏 上 “窗口 ”一 “行为 ”命令 ,打开 “行为 ”面板 , 单 击 “ 行 
为 ”面板 中 的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 ， 选 择 “ 检 查 表单 ”选项 ， 打 开 “检查 表单 ” 
对 话 框 ， 设置 “ 值 ”和 “可 接受 ”范围 ， 如 bbs_email 的 “ 值 ”设置 为 “必需 的 ”、“ 可 接 
受 ” 为 “电子 邮件 地 址 ”， 如 图 8-59 所 示 。 


地 入 后， 四 由 md phe 


图 8-58 设 定 " 插 入 记录 图 8-59 “检查 表单 ”对 话 框 
单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 bbs_add.php 页 面 插入 记录 的 设置 。 
按 F12 键 至 浏览 器 测试 一 下 。 首 先 打开 bbs_add.php 页 面 再 填写 表单 ， 填 写 表 单 资 
料 如 图 8-60 所 示 。 
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PHPi 论 坛 诈 理 系统 。 | 闪 s#x | 发 证 | 曲 复 主题 | 后 生理 本 


EE 


图 8-60 填写 资料 


四 填写 资料 完了 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs_main 数 据 表 中 。 
页 面 将 返回 到 BBS 讨论 系统 主页 面 index.php (如 图 8-61 所 示 ) ， 表 示 发 布 新 主题 成 功 。 
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127.0.01/bbs 


x 


| 论坛 首页 | 发 表 主题 ”| 回复 主题 “| 后 台 管理 


图 8-61 发 表 新 主题 成 功 


94) 回复 讨论 


回复 讨论 主题 页 面 bbs_reply.php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 ， 回 复 主题 是 
将 表单 中 填写 的 数据 插入 到 bbs_ref 数 据 表 中 ， 页 面 设计 效果 如 图 8-62 所 示 。 


PHP 论 坛 管理 系统 。 “| 论坛 # 页 | 发 表 主 题 | 回复 主题 ”| 后 台 管 理 


a 


es 


一 


属性 


EE 


由 


9 


| 担 甸 芝 要 用 


图 8-62 ”回复 讨论 主题 页 面 设计 

加 由 于 在 讨论 主题 内 容 页 面 content.php 中 ， 设 定 会 有 传递 参数 bbs_ID (主题 编号 ) 
传递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs_main_ ID 的 隐藏 域 中 。 在 
页 面 上 插入 一 下 隐藏 域 ， 并 命名 为 bbs_main ID， 定义 其 值 ， 如 图 8-63 所 示 。 


值 ) 


ophp echo $bbs_main_ID ?> 


机 


<2php 


图 8-63 设置 隐藏 域 bbs_main_ID 的 值 
然后 再 单 击 [代码 按钮 ， 切 换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 一 行 : 


$bbs _ main ID=strval($ GET['bbs_ID']); 


Ee 
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插入 后 如 图 8-64 所 示 。 


Dw en wa ee i em wo 00 en so em 可 国 @l=lsLx] 


加 Ws s* 区 


日 


图 8-64 插入 接收 变量 的 程序 
再 插入 一 个 隐藏 字段 bbs_ref time， 绑 定 为 当时 的 时 间 : 


<?PhP 

date default timezone set('Asia/Shanghai'); 
echo date("Y-m-d"); 

?> 


属性 面板 的 设置 如 图 8-65 所 示 。 
属性 


IN 隐 疗 区 域 


|bbs_ref_tind 值 @) | 人?phpdate_default_timezrone_set(| 仿 


图 8-65 ”设置 隐藏 区 域 值 

贺 在 bbs reply.php 编 辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 “服务 器 行为 ”面板 标签 
中 的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “插入 记录 ”选项 ， 在 “插入 记录 ”的 设 定 对 话 框 
中 设置 如 下 : 

@ 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作 为 数据 源 连 接 对 象 。 

@ 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs_ref 作 为 使 用 的 数据 库 表 对 象 。 

@ 在 “插入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_ref， 然 后 再 转 到 index.php 

网 页 。 
@ 在 “ 列 ” 列 表 框 中 ， 将 表单 对 象 和 数据 库 中 表 bbs_ref 中 的 字段 一 一 对 应 起 来 。 
设置 完成 后 该 对 话 框 如 图 8-66 所 示 。 
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图 8-66 “插入 记录 ”对 话 框 
选择 表单 ， 执 行 菜单 栏 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 国 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 打 开 “ 检 查 表单 ”对 
话 框 ， 设 置 文本 域 的 “ 值 ”都 为 “必需 的 ”、“ 可 接受 ”为 “任何 东西 ”， 其 中 邮件 字段 
设置 为 “电子 邮件 地 址 ”， 如 图 8-67 所 示 。 


二 = 可 
- 
李冰 
E77 
可 接受 ， 司 任何 东西 OD MF 
| 图 电子 邮件 地 址 。 站 至 字 从 到 
ee = 


图 8-67 “检查 表单 ”对 话 框 
单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 这 样 就 完成 bbs_reply.php 页 面 插入 记录 的 设 
主子， 
按 F12 键 至 浏览 器 测试 。 首 先 打 开 首 页 面 ， 选 择 其 中 任 一 个 讨论 主题 ， 进 入 
content.php 页 面 ， 在 content.php 页 面 单 击 “回复 主题 ” 转 到 回复 讨论 主题 bbs_reply.php 页 面 ， 
在 bbs_reply.php 页 面 填写 表单 ， 填 写 表单 资料 如 图 8-68 所 示 。 


让 [ED 
二 可 胡 | 码 回 FP5a27001 Bev 


es 


Ea 
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> 
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ES 
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图 8.68 填写 表单 资料 
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国 填写 资料 完了 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs_ref 数 据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index.php， 在 单 击 主题 后 可 以 看 到 回复 如 图 8-69 所 
示 ， 表 示 回 复 主题 成 功 。 


EE 7 EE 


所 所 表 去 轩 127.0.0.1 | BEvY 
a | 
fp | 
"A LA 
讨论 开题: 测 江 站 [ea 
| 
昌 二 Py 这 Pd, 两 芝 
wa | DN Oa CE 
县 ear: santusaa 
RA: we MN 


图 8-69 回复 主题 成 功 
1 8.5 ”论坛 管理 后 台 
论坛 管理 系统 的 后 台 管 理 比较 重要 ， 访 问 者 在 回复 主题 时 回复 一 些 非法 或 者 不 文明 的 
信息 时 ， 管 理 员 可 以 通过 后 人 台 对 这 些 信息 进行 删除 。 
-和 851 ) 版 主 登录 
由 于 管理 页 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受 到 权限 管理 ， 可 以 利用 管理 员 账 号 
和 管理 密码 来 判别 是 否 有 此 用 户 ， 设 计 如 图 8-70 所 示 。 


mm. th ol-lel* 
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图 8-70 “BBS 论坛 系统 后 台 管 理 登录 页 面 ”设计 

其 详细 操作 步骤 如 下 : 

加 打开 后 台 版 主 登 录 页 面 admin_ login.php， 单 击 “应 用 程序 ”面板 中 的 “服务 器 行 
为 ”标签 上 的 团 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “用 户 身份 验证 /登录 用 户 ” 选 项 ， 在 打开 
“登录 有 用户” 对话 框 中 设置 如 果 不 成 功 将 返回 BBS 论坛 系统 主页 面 index.php， 如 果 成 功 将 
转向 后 台 版 主管 理 页 面 admin.php， 设 置 如 图 8-71 所 示 。 
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日 转 到 前 一 个 URLG0 果 亡 存 在 ) 
如 果 登 录 失 败 ， 转 到 indsx phy EF 


基于 以 下 项 限制 访问 : 于 用 户 名 和 密码 


图 871 “登录 用 户 ” 的 设置 
选择 表单 ， 执 行 菜单 栏 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 固 按 钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “检查 表单 ”选项 ， 打 开 “ 检 查 表单 ”对 
话 框 ， 设 置 username 和 password 文 本 域 的 “ 值 ”都 为 “必需 的 ”、“ 可 接受 ”为 “任何 东 
西 ”， 如 图 8-72 所 示 。 


图 8-72 “检查 表单 "对 话 框 
单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 现 在 后 台 版 主 登录 页 面 admin_login.php 的 设 
计 与 制作 都 已 经 完成 ， 如 图 8-73 所 示 。 


wm 
图 8-73 设置 完毕 的 版 主 登录 页 面 


< 后 552 ) 版 主管 理 


BBS 论坛 管理 系统 的 后 台 版 主管 理 页 面 是 版 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 
面 。 这 个 页 面 主要 为 版 主 提供 对 数据 的 新 增 、 修 改 、 删 除 内 容 的 功能 。 后 台 版 主管 理 页 面 
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admin.php 的 内 容 设 计 与 BBS 论坛 系统 主页 面 index.php 大 致 相同 , 不同 的 是 加 入 可 以 转 到 所 
编辑 页 面 的 链接 ， 页 面 效果 如 图 8-74 所 示 。 


函 cwamepWedoceobeaaminpnp -Dx 
UY Hn 


PHP 论 坛 管 理 系 统 1 论坛 首页 | 发 表 主题 | 回复 主题 | 后 台 管 理 
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下 前 没有 发 表 任何 主题 


ID 
EEE TE 


图 8-74 后台 版 主管 理 页 面 的 设计 


在 后 台 版 主管 理 页 面 admin.php 中 ， 动 态 显示 部 分 和 index.php 是 一 样 的 ， 所 以 可 以 
直接 将 index.php 保 存 为 admin.php 页 面 ， 然 后 再 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 每 个 
讨论 主题 后 面 都 各 有 一 个 “修改 ”按钮 和 “删除 ”按钮 ， 它 们 分 别 是 用 来 修改 和 删除 某 个 
讨论 主题 的 ， 但 不 是 在 这 个 页 面 执 行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 
进行 相应 的 操作 。 

单 击 admin.php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”为 
del_title.php?bbs_ID=<?php echo Srow_rs_bbs["bbs_ID']; ?>， 如 图 8-75 所 示 。 


属性 
图 你 区 宽 m156 | 源 文件 G)linsees/dele af |@ 已 曾 扫 中 | ~ 类 C[ 无 
Im | 高 0 5 | 庆 接 LEERECIG GO 已 全 和 P 
地 图 0 ] 看 直 边 距 WV) 目标 四 eo MO 
加 口 口 已 ED | 原则 JD FNM 加 


图 8-75 设置 “链接 ”属性 


单 击 admin.php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”为 
upd_title.php?bbs_ID=<?php echo $row_rs_bbs["bbs_ ID']; ?>， 如 图 8-76 所 示 。 


属性 
图 像 ， 1K 。 宽 D 16 | 涯 文件 5) |inaee: 
到 商 0116 | ”入 接 tL) wpa 

地 图 人 重 直 边 距 W) | | ”目标 QQ)| 


[RN] DO AuEDL[ | 原始 
图 8-76 设置 “链接 ”属性 
由 于 讨论 区 的 管理 权限 是 属于 版 主 的 ， 因 此 必须 设 定 本 页 面 “限制 对 页 的 访问 ” 
的 服务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 上 的 固 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “用 户 身 
份 验证 ”一 “限制 对 页 的 访问 ”选项 ， 打 开 “ 限 制 对 页 的 访问 ”对 话 框 ， 选 中 “用 户 名 和 
密码 ” 单 选 按 钮 ， 如 果 访 问 被 拒绝 ， 将 转向 admin login.php， 如 图 8-77 所 示 。 
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| 基于 以 下 内 容 进行 限制 加 ”用户 加 和 乍 碍 


用户 名 、 密 码 和 访问 级 别 


ST 


如 果 访问 补 拒 绝 ， 风 到 :wanin_Ioein php 


< 853 删除 讨论 


删除 讨论 页 面 del_title.php 的 功能 不 只 是 要 删除 所 指定 的 主题 ， 还 要 将 跟 此 主题 相关 的 回 
复 留言 从 资料 表 bbs_ref 中 删除 ， 页 面 设计 效果 如 图 8-78 所 示 。 
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图 8-77 设置 对 页 的 访问 


php' x 


PHP 论 坛 铝 理 系统 。 | 二 WW | 发 表 主 题 | 回复 主题 | 后 各 和 再 


图 8-78 删除 讨论 页 面 的 设计 


详细 操作 步骤 如 下 : 

打开 删除 讨论 页 面 del_title.php, 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 团 
按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”的 选项 ， 在 打开 的 “记录 集 ” 对 话 框 
中 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语法 改 成 以 下 的 SQL 语 
法 ， 如 图 8-79 所 示 。 


SELECT bbs main.*,bbs ref.* 
FROM bbs_ main LEFT OUTER JOIN bbs ref ON bbs main.bbs_ID=bbs_ref.bbs_ 


main_ID 
WHERE bbs main.bbs_ID ='".$bbs_ID."' 
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圭 据 库 项 :| 下 “Bl SQL 


图 8-79 改写 SQL 语句 


加 上 图 中 设置 了 一 个 名 为 Sbbs_ID 的 变量 值 ， 即 是 admin.php 传 递 过 来 的 参数 ， 因 此 
在 该 页 自动 生成 的 PHP 代 码 中 的 第 一 行 加 入 如 下 的 变量 赋值 : 
$bbs_ID=strval($ GET['bbs_ID']); 


在 设 定 完 记 录 集 绑 定 后 , 把 rs 记录 集中 的 字段 插入 到 del title.php 页 面 上 ,如 图 8-80 


| 论坛 首 页 | 发表 主题 “| 回复 主题 | 后 各 管理 


图 8-80 del_title.php 中 的 字段 插入 


贺 在 页 面 中 插入 一 个 隐藏 字段 bbs ID， 将 这 个 变量 绑 定 至 删除 讨论 页 面 del_titlephp 
中 的 隐藏 字段 bbs ID。 如 图 8-81 所 示 。 


图 8-81 插入 字段 到 隐藏 域 中 


完成 页 面 的 字段 设置 后 ， 接 着 要 在 del title.php 页 面 加 入 “删除 记录 ”的 设置 ， 具 
体 的 设置 如 图 8-82 所 示 。 
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国 882 “删除 记录 对 话 杠 
四 单 击 “ 确 定 ”按钮 ， 完 成 删除 讨论 页 面 的 设置 。 
-554 ) 修 改 讨论 
修改 讨论 主题 页 面 upd_titlephp 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs_main 数 据 表 中 ， 
页 面 设计 如 图 8-83 所 示 。 
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图 8-83 修改 讨论 主题 页 面 
操作 步骤 如 下 : 


加 打开 修改 讨论 主题 页 面 upd_title-php， 单 击 “ 绑 定 ” 面 板 上 的 国 按钮 ， 在 弹出 的 下 
拉 菜 单 中 选择 “记录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “高 级 ”按钮 ， 
进入 记录 集 高 级 设 定 的 页 面 ( 如 图 8-84 所 示 ) ， 将 现 有 的 SQL 语法 改 成 以 下 的 SQL 语法 : 
SELECT bbs main.*,bbs ref.* 


FROM bbs_ main LEFT OUTER JOIN bbs_ref ON bbs main.bbs_ID=bbs_ ref.bbs_ 
main_ID 
WHERE bbs main.bbs_ID ='".$bbs_ID.™' 
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图 8-84 改写 SQL 语句 


上 图 中 设置 了 一 个 名 为 Sbbs_ID 的 变量 值 ， 即 是 admin.php 传 递 过 来 的 参数 ， 因 此 
在 该 页 自动 生成 的 PHP 代 码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID=strval($ GET['bbs ID']); 


在 设 定 完 记 录 集 绑 定 后 , 把 记录 集 rs 中 的 字段 插入 到 upd_title.php 页 面 上 , 如 图 8-85 
er 
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PHP 论 坛 乱 理 系统 。 | 这 :机 是 | 回复 主题 | 所 和 


三 下 
图 8-85 upd title.php 中 的 字段 插入 
加 在 页 面 中 插入 一 个 隐藏 字段 bbs ID, 将 这 个 变量 绑 定 至 删除 讨论 页 面 upd_title.php 
中 的 隐藏 字段 bbs ID， 如 图 8-86 所 示 。 
属性 


让 Pe 


[3 


ophp echo $row_rs[’ bbs_ID ]; ?有 


图 8-86 插入 字段 到 隐藏 域 中 
完成 页 面 的 字段 设置 后 ， 接 着 要 在 upd title.php 页 面 加 入 “更 新 记录 ”的 设置 。 打 
开 “ 更 新 记录 ”对 话 框 ， 设置 如 图 8-87 所 示 。 
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第 8 章 ”全程 实例 六 : 网 站 论坛 管理 系统 
。 ee 


图 8-87 “更 新 记录 ”对 话 框 
_ 国 单 击 “ 确 定 ” 按 钮 ， 完 成 修改 讨论 主题 页 面 的 设置 。 
< 555 ) 删 除 回复 


删除 回复 页 面 del_reply.php 功能 是 将 表单 中 的 数据 从 网 站 的 数据 表 bbs_ref 中 删除 。 主 要 
目的 是 ， 管 理 员 对 一 些 不 文明 和 非法 的 回复 信息 进行 删除 。 sa 所 示 。 


| 论坛 首页 | 省 主题 ”| 固 复 主题 ”| 所 各 管理 


图 8-88 del_reply.php 页 面 的 设计 效果 图 
其 详细 的 操作 步骤 如 下 : 
贺 打开 后 台 版 主管 理 页 面 admin.php 并 单 击 标题 ， 进 入 del_reply.php 页 面 。 只 要 在 标 
题 的 属性 栏 将 链接 到 的 页 面 修改 一 下 参数 为 del reply.php 就 可 以 实现 这 功能 ， 如 图 8-89 所 
示 。 


属性 

[<> rmL| | 格式 @) | 无 ~ 

上 css Ia) 无 v el reply. php?bbs id= ?php e 司 

国 单元 格 水平 C) 默认 Y 宽 们 不 换行 0) 口 ” 背 晤 颜色 (c) 厂 -| CERE ] 
口疮 ” 生 下 中 | 默认 | 高 们 | 40| 标题) 口 


图 8-89 属性 链接 设置 
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ps el a 实例 (第 2 版 ) 


贺 在 del_reply.php 页 面 , 单 击 “ 绑 定 ” 面板 上 的 团 按 钮 , 在 弹出 的 下 拉 菜 单 中 选择 “ 记 
录 集 (查询 ) ”选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “高 级 ”按钮 ， 进 入 记录 和 集 高 级 
设 定 的 页 面 ( 如 图 8-90 所 示 ) ， 将 现 有 的 SQL 语法 改 成 以 下 的 SQL 语法 : 

SELECT bbs main.*,bbs ref.* 

FROM bbs main LEFT OUTER JOIN bbs_ref ON bbs _main.bbs_ID=bbs_ref.bbs_ 

main_ ID 

WHERE bbs main.bbs_ID ='".S$bbs_ ID."!" 


[aa 本 一] 
| EBD | 
| 
CM 
认 值 : 
坊 辑 
数据 床 项 | 田 团 Er 添加 中 SQL 
因 
mR se Cr 
WHERE 
ORDER BY 
| 


图 8-90 改写 SQL 语句 
在 该 页 自动 生成 的 PHP 代 码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID=strval($ GET['bbs_ID']); 


加 在 设 定 完 记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 del reply.php 页 面 上 ， 如 图 
8-91 所 示 。 


图 8-91 del_reply.php 中 的 字段 插入 


在 页 面 中 插入 一 个 隐藏 字段 bbs ID, 将 这 个 变量 绑 定 至 删除 讨论 页 面 del_reply.php 
中 的 隐藏 字段 bbs ID， 如 图 8-92 所 示 。 
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第 8 章 全 程 实例 六 : 网 站 论坛 管理 系统 @ 
~”.° 


NI tbs ID 值 W) | 人 php echo grov_rs[ bbs ID ]: ?用 


图 8-92 插入 字段 到 隐藏 域 中 


四 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del_reply.php 页 面 加 入 “删除 记录 ”的 设 定 ， 打 
开 “ 删 除 记 录 ” 对 话 框 ， 设 置 如 图 8-93 所 示 。 


首先 检查 是 已 定义 交 蛙 :[ 主 证 = Cj) 
连接 : |bbs 四 取消 
| 表格 : [bbs_xef 四 寺 助 
主键 列 : [bbs_ref_ID 9] 团 数值 
主键 值 [URL 参数 | bbs_ref_ID 
删除 后 ， 转 到 :admin. php 浏览. 


图 8-93 “删除 记录 ”对 话 框 


本 实例 到 这 一 步骤 就 已 经 开发 完成 ， 读 者 通过 学 习 已 经 掌握 了 网 站 论坛 管理 系统 的 开 
发 方法 。 在 实际 的 网 站 开发 应 用 中 ， 可 以 结合 本 实例 的 一 些 技巧 开发 出 功能 更 强大 ， 需 求 
更 多 的 大 型 网 站 论坛 管理 系统 。 
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第 章 


全 程 实 例 七 : 莫 寻 电子 商城 前 台 


网 上 购物 系统 通常 拥有 产品 发 布 功能 、 订 单 处 理 功 能 、 购 物 车 功能 等 动态 功能 。 管理 
者 登录 后 台 管 理 ， 即 可 进行 商品 维护 和 订单 处 理 操作 。 从 技术 角度 来 说 主要 是 通过 “购物 
车 ”就 可 以 实现 电子 商务 功能 。 网 络 商店 是 比较 庞大 的 系统 ， 它 必须 拥有 会 员 系统 、 查 询 
系统 、 购 物流 程 、 会 员 服 务 等 功能 模块 ， 这 些 系统 通过 用 户 身份 的 验证 统一 进行 使 用 ， 从 
技术 角度 上 来 分 析 难 点 就 在 于 数据 库 中 各 系统 数据 表 的 关联 。 本 章 主要 介绍 使 用 PHP 进 行 
网 上 购物 系统 前 台 开 发 的 方法 ， 将 系统 地 介绍 翡翠 电子 商城 的 前 台 设 计 ， 数 据 库 的 规划 以 
及 常用 的 几 个 功能 模块 前 台 的 开发 。 


本 章 的 学 习 重点 : 

翡 潼 电子 商城 的 系统 规划 
数据 库 的 设计 

首页 动态 功能 开发 

会 员 管理 系统 功能 开发 
新 闻 系 统 的 开发 

产品 的 定购 功能 开发 
购物 车 功能 的 开发 


本 ee。 


过 9.1 ， 碍 在 电子 商城 系统 规划 


为 了 能 系统 地 介绍 使 用 PHP 建 设 电 子 商 务 网 站 的 过 程 ， 本 章 将 模拟 一 个 实用 的 翡翠 电 
子 商城 网 站 的 建设 过 程 为 例 ,来 详细 介绍 网 站 想 拥有 一 个 网 上 购物 系统 必须 做 哪些 具体 工 
作 。 在 进行 大 型 系统 网 站 开发 之 前 首先 要 做 好 开发 前 的 系统 规划 ， 方 便 程 序 员 进行 整个 网 
站 的 开发 与 建设 。 
<- 911) 电子 商城 系统 功能 

B2C 电 子 商 城 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 ， 让 访问 者 在 网 络 上 购 
物 。 网 上 购物 以 及 网 上 商店 的 出 现 ， 避 免 了 挑选 商品 的 烦琐 过 程 ， 让 人 们 的 购物 过 程 变 得 
轻松 、 快 捷 、 方 便 ， 很 适合 现代 人 快 节奏 的 生活 ; 同时 又 能 有 效 地 控制 “商场 ”运营 的 成 
本 ， 开 辟 了 一 个 新 的 销售 渠道 。 本 实例 是 使 用 PHP+MySQL 直 接 用 手写 程序 完成 的 实例 ， 
完成 的 首页 如 图 9-1 所 示 。 


专 妆 万全 | 太田 127.001 Lev 


sc ”i 
he HN 


名 i 


sn wa ea: L223 


图 9-1 翡 淤 电子 商城 首页 
本 网 站 主要 能 够 实现 的 功能 如 下 : 


(1) 开发 了 强大 的 搜索 以 及 高 级 查询 功能 ， 能 够 快捷 地 找到 感 兴趣 的 商品 。 

(2) 采取 会 员 制 保证 交易 的 安全 性 。 

(3) 流畅 的 会 员 购物 流程 : 浏览 、 将 商品 放 入 购物 车 、 去 收银 台 。 每 个 会 员 有 自己 
专用 的 购物 车 ， 可 随时 订购 自己 中 意 的 商品 结账 完成 购物 。 购 物 的 流程 是 指导 购物 车 系统 
程序 编写 的 主要 依据 。 

(4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 详情 。 

(5) 设计 会 员 价 商品 展示 ， 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 

(6) 人 性 化 的 会 员 与 网 站 留言 ， 可 以 方便 会 员 和 管理 者 的 沟通 。 

(7) 后 台 管 理 模块 ， 可 以 通过 使 用 本 地 数据 库 ， 保 证 购物 定单 安全 及 时 有 效 地 处 理 
强大 的 统计 分 析 功 能 ， 便 于 管理 者 及 时 了 解 财务 状况 、 销 售 状况 。 


- 309 - 


sa 网 站 开发 全 程 实例 (第 2 版 ) 
BR 


y 功能 模块 需求 分 析 
将 要 建设 的 电子 商城 系统 主要 由 如 下 儿 个 功能 模块 组 成 


(1) 前 人 台 网 上 销售 模块 。 指 客户 在 浏览 器 中 所 看 到 的 直接 与 店主 面对面 的 销售 程序 
包括 ， 浏 览 商品 ， 订 购 商品 ， 查 询 定 购 ， 购 物 车 等 功能 ， 本 实例 的 搜索 页 而 如 图 9-2 所 示 。 


WM [= |X 


127.0.0.1 BEY 


秃 妇 时 尽 


JADE WEN 


2012-3-1 查看 购物 


Tuderen 


1 全 业 简介 | 加 归 连 镶 | 招聘 内 位 | 联系 委 们 


图 92 用户 搜索 结果 效果 
(2) 后 台数 据 录入 模块 。 前 台所 销售 商品 所 有 数据 ， 其 来 源 都 是 后 台所 录入 的 数据 。 
后 台 的 产品 录入 页 面 ， 如 图 9-3 所 示 。 


EB 1500 人 E71 Re 义 


拟 | 妃 胡 六 | 加 127.0.0.1 BEY 


ET 


图 9-3 用户 搜索 界面 效果 


(3) 后 台数 据 处 理 功 能 模块 。 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 ， 
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都 放 在 销售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 
处 理 页 面 如 图 9-4 所 示 。 


EF 
| 五 | 硼 广 加 127.0.0.1 


Ls 


是 后 台数 据 处 理 模 块 的 功能 。 后 台 订 单 


电台 官 理 
”Ba | 
0 Tr 
人 kA 订 昌 下 平和 | 订 终 人 | 了 9 计 | 个 F 二 下 由 二 EEE 襄 作 
J 信 5005I3596 | 阳 % | 险 二 | won | 训 & 忆 和 5 芝 | 。 昔 邮 | 
Fl 一 1 
EE -3608 1 yr 
| | 
4 加 127.001 
洒 间 201ZDCZS05132945 了 EN | | 打印 
5 康 各 T); 
Er 4 ‘0D leo 
BTR em 
FR 人 
[To 
中 斤 和 地 :北京 市 
邮 罚 : 。 loncen 到 未 lsecolseco0 
Ee peiga 5 


图 94 后 台 定 单 处 理 页 面 


(4) 用 户 注册 功能 模块 。 用 户 当 然 并 不 - 
候 都 可 以 来 买 东西 ， 用 户 注册 的 好 处 在 于 
账号 和 密码 输入 就 可 以 了 ， 会 员 注 册页 面 如 图 9-5 所 示 。 


| 二 从 太 | 固 


ET © ms 


127.0.0.1 


- 定 立 即 就 要 买 东西 ， 可 以 先 注 册 ， 任 何 时 
东西 后 无 须 再 输入 一 大 堆 个 人 信息 ， 


只 须 将 


翡 轴 质 你 


IADE N 


(5) 订单 号 模块 。 客 户 购买 完 商品 后 ， 系 统 自动 分 配 一 个 购物 号 码 给 客户 ， 以 方便 
客户 随时 查询 账单 处 理 情况 ,了 解 现 在 货物 的 状态 。 客户 订购 后 结算 中 心 页 面 效 果 如 图 9-6 


所 示 。 
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SA。 网 站 开发 全 程 实例 (第 2 版 ) 
SS © 


dos 人 
Bgl 四 
ER pmp/ D0I dd=2015012901474004 EET WindD i memet Explorer [ee 


二 tert 直下 具 的 和 评 T 了 此 7 间 并 5 


图 9-6 结算 页 面 
(6) 会 员 留 言 模块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实现 回复 的 功能 ， 真 正 
做 到 处 处 为 顾客 着 想 ， 留 言 页 面 如 图 9-7 所 示 。 


| 生 360 安 主 沿 晤 71 于 曾 一 品 |X 
分 全 | 妇 | 四 127.001 BEYv 
ras: 上 


JADE WEN 


当前 用 户 阳光 ， 修 欢 个 人 信息 为 用户 留言 》 修 将 玛 ? 福 销 高 肛 
用户 久 言 


窗 言 主题 : 


留言 内容: 


图 9-7 用 户 留言 页 面 


< 958) 网 站 整体 规划 


在 制作 网 站 之 前 首先 要 把 设计 好 的 网 站 内 容 放 置 在 本 地 计算 机 的 硬盘 上 ， 为 了 方便 站 
点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 一 个 目录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 。 
在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 然 
后 在 其 中 再 创建 多 个 子 文件 夹 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 读 者 可 以 下 载 本 
书 提供 的 素材 , 看 下 第 9 章 的 站 点 文档 结构 ， 及 文件 夹 结构 ,设计 完成 的 结构 如 图 9-8 所 示 。 
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Sipe, © 
e ee 
fx 
OE “er » wmpp » mdocs » shop » ™ [4 || ss bop P| 
文件 坊 二 (日 查看 V) 工具 Mm 帮助 (H) 
扣 R” 。 包 4 到 寺 T”  # 享 ” 刻录。 六 XH 习 |"| 了 @ 
EE * Bnots 上 上 admin 四 
国 迅 BT 苇 区 四 二 
直言 | da Bimages 了 
| a addgounche.php Dagreeregphp 国 
于 计算 册 botom.php changeuserphp 
| 名 Acro 日 chargeuserpwd php chiuserphp 
点 adobeTemp 目 chkusemcphp 目 deletealLphp 
B BJCAAPP Dendconn.pnp Dfinddd.php 
BB BJCAROOT findpwd.php function.php 
页 debug = qongqao.php gongqaolstphp - 
| ] 49 人 对象 


图 9-8 ”网 站 文件 结构 
首先 对 本 商城 的 前 台 页 面 进行 一 下 规划 设计 ， 对 需要 设计 的 页 面 功能 分 析 如 下 : 
addgouwuche.php: 添加 定购 的 商品 到 购物 车 gouwuche.php 页 面 
agreereg.php: 同意 注册 页 面 
bottom.php: 网 站 底部 版 权 
changeuser.php: 用 户 注册 信息 更 改 页 面 
changeuserpwd.php: 更 改 登 录 密 码 页 面 
chkuser.php: 登录 身份 验证 页 面 
chkusernc.php: 检查 昵称 是 否 被 用 文件 
conn/conn.php: 数据 库 连 接 文件 
deleteall.php: 删除 用 户 处 理 页 面 
finddd.php: 订单 查询 页 面 
findpwd.php: 找 回 密码 功能 的 页 面 
serchorder.php: 查找 到 商品 显示 页 面 
function.php: 系统 调用 的 常用 函数 
gouwuche.php: 购物 车 页 面 
gouwusuan.php: 收银 台 结算 页 面 
highsearch.php: 高 级 查找 页 面 
index.php: 网 站 购物 车 首页 
left_ menu.php: 用 户 及 公告 系统 
logout.php: 用 户 退 出 页 面 
lookinfo.php: 详细 商品 信息 
openfindpwd.php: 找 回 密码 回答 答案 页 面 
reg.php: 用 户 注 册 开 始 页 面 
removegwc.php: 购物 车 移 除 指定 商品 页 面 
savechangeuserpwd.php: 更 改 用 户 密 码 页 面 
savedd.php: 保存 用 户 订单 页 面 
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= 


从 上 面 的 分 析 统 计 该 


Eso 


savepj.php: 保存 商品 评价 页 面 
savereg.php: 保存 用 户 注册 信息 
saveuserleaveword.php: 保存 用 户 留言 页 面 
showdd.php: 显示 详细 订单 页 面 
showfenlei.php: 商品 分 类 显示 页 面 
gonggao.php: 显示 详细 公告 内 容 页 面 
gonggaolist.php: 公告 罗列 分 页 显示 页 面 
showhot.php: 热门 商品 页 面 
shownewpr.php: 最 新 商品 页 面 
showpp.php: 商品 销售 排行 页 面 
showpl.php: 商品 评论 分 页 显示 页 面 
showpwd.php: 用 户 找 回 的 密码 页 面 
showtuijian.php: 推荐 商品 页 面 

top.php: 网 站 顶部 导航 条 

usercenter.php: 会 员 中 心 页 面 
userleaveword.php: 发 表 留 言 页 面 


辫 网 站 前 台 总 共 由 41 个 页 面 组 成 ,涉及 到 了 动态 网 站 建设 几乎 所 有 


的 动态 功能 开发 设计 。 
有 1 9.2 ”系统 数据 库 设计 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 的 时 候 需要 从 使 用 的 功能 模块 入 手 ， 
可 以 分 别 创建 不 同 命名 的 数据 表 ， 命 名 的 时 候 也 要 与 使 用 的 功能 命名 相配 合 ， 方 便 后 面相 
关 页 面 设计 制作 时 的 调用 , MySQL 数 据 库 的 制作 方法 在 前 面 的 章节 中 也 介绍 过 很 多 次 , 本 


音节 将 要 完 


成 的 数据 库 命名 为 db_shop， 在 数据 库 中 建立 8 个 不 同 的 数据 表 ， 如 图 9-9 所 示 。 
于 | 
[A ~ i has/12700Uphomyadin(sPMAURL ldb strucrs php ab- cb shopseable~ Server- amaroct-snc 国 ~ Ox 


| 1270011 127001 7 db 
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图 9-9 建立 的 db_shop 数据 库 
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@ 
3 °° 
< 入 921) 设计 商城 数据 表 


数据 库 db_shop 里 面 是 根据 开发 的 网 站 的 几 大 动态 功能 来 设计 不 同 数据 表 的 , 本 实例 需 
要 创建 8 个 不 同 的 数据 表 ， 下 面 分 别 介 绍 一 下 这 些 数 据 表 的 功能 及 设计 的 字段 要 求 : 


(1) tb_admin 是 用 来 储存 后 台 管理 员 的 信息 表 ， 设 计 的 tb_admin 数 据 表 ， 如 图 9-10 所 
示 。 其 中 name 是 管理 员 名 称 ，pwd 是 管理 员 密 码 。 
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图 9-10 后 台 管 理 者 表 tb_admin 


(2) tb_dingdan 是 用 来 储存 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 设 计 的 tb_dingdan 数 
据 表 ， 如 图 9-11 所 示 。 
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图 9-11 用 户 订 单 表 tb_ dingdan 
(3) tb_gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 设 计 的 tb_gonggao 数 据 表 ， 如 图 9-12 
所 示 。 
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图 9-12 网 站 公告 表 tb_gonggao 


(4) tb_leaveword 是 用 户 给 网 站 管理 者 留言 的 数据 表 ， 设 计 的 tb_leaveword 数 据 表 ， 


如 图 9-13 所 示 。 
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图 9-13 ”用户 留言 表 tb_leaveword 
(5) tb_pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 设 计 的 tb_pingjia 数 据 表 ， 
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图 9-14 商品 用 户 评价 表 tb_pingjia 
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如 图 9-14 所 示 。 


(6) tb_shangpin 是 商品 表 ， 购 物 系 统 中 核心 的 产品 发 布 ， 定 购 时 的 结算 都 要 调用 该 数 


据 表 的 内 容 ， 设 计 的 tb_shangpin 数 据 表 ， 如 图 9-15 所 示 。 


所 示 。 
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图 9-15 商品 表 tb_shangpin 


(7) tb_type 是 商品 的 分 类 表 ， 设 计 的 tb_type 数 据 表 ， 如 图 9-16 所 示 。 
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图 9-16 商品 分 类 表 也 _type 
(8) tb_user 是 用 来 保存 网 站 会 员 注册 用 的 数据 表 ， 设 计 的 tb_user 数 据 表 ， 如 图 9-17 
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图 9-17 ”网 站 用 户 信息 表 tb_user 
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上 面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 问 主要 通过 产品 的 类 别 ID 关联 ， 
建立 网 站 所 需要 的 主要 内 容 信息 ， 都 能 储存 在 数据 库 里 面 。 

人 9.2.2 ) 建 立 网 站 本 地 站 点 

定义 站 点 的 具体 操作 步骤 如 下 : 


国 首先 在 C:\xampphtdocs 路 径 下 建立 shop 文 件 来 ( 如 图 9-18 所 示 ) ,本章 所 有 建立 的 
PHP 程 序 文件 都 将 放 在 该 文件 夹 底下 。 
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和 口 - 睛 ， 计算 机 Acer (cj 、xampp » htdocs » 7 [4]| Rs htdocs P| 
文件 (篇 纺 (E) 查看 (V) 工具 (帮助 (H) 
扯 织 ” 。 演 打 开 。 包 全 到 村 中” 共享” 。 刘 好 新 建文 件 天 状 " 加 @ 
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图 9-18 建立 站 点 文件 夹 shop 


贺 打开 Dreamweaver CC， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 如 图 9-19 
所 示 ， 打 开 “ 管 理 站 点 ”对 话 框 。 
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图 9-19 “管理 站 点 ”对 话 框 
加 单 击 “ 新 建 ”按钮 ， 打 开 “ 站 点 设置 对 象 shop” 对 话 框 ， 如 图 9-20 所 示 设置 参数 。 
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图 9.20 建立 shop 站 点 
单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “添加 服务 器 ”按钮 国 ]， 打 开 “ 基 本 ” 
选项 卡 进行 如 图 9-21 所 示 的 参数 设置 。 


图 9-21 “基本 ”选项 卡 设置 
设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 同步 
信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL， 表 示 是 使 用 PHP 开 发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 9-22 所 示 。 


图 9-22 设置 “高 级 ”选项 卡 
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二 os SL 全 实例 (第 2 版 ) 


国 单 击 “ 保 存 ” 按 钮 返回“ 服务 器 ”设置 界面 ， 再 单 击 选 择 上 “测试 ” 复 选 框 ， 
如 图 9-23 所 示 。 
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图 9-23 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CC 测试 shop 网 站 
环境 设置 。 
< 923 ) 建 立 数据 库 连 接 
数据 库 设 计 之 后 ， 需 要 将 数据 库 链 接 到 网 页 上 ， 这 样 网 页 才能 调用 数据 库 和 储存 相应 
的 信息 。 用 PHP 开 发 的 网 站 ， 一 般 将 数据 库 链接 的 程序 代码 文件 命名 为 conn.php。 在 站 点 
文件 夹 创 建 conn.php 空 白 页 面 ， 按 如 图 9-24 所 示 输 入 数据 库 链 接 代码 。 


cvaneoVoonhon eonnn he 基本 区 
K?php 
Siconn=aysql_connect (“localhost’, “root”, ) or die( 
和 “数据 库 服务 器 连接 模 误 ". nysql_error ()) 


mysql_select_db("db_shop”, $conn) or die(" 数 据 库 访问 错误 "。 
mysql_error() 

4 nysql_query ("set character set gb2312"); 

区 | 5 mysql_query ("set nanes gb2312"); 

?> 


图 9-24 设置 数据 库 连 接 
对 于 本 连接 的 程序 说 明 如 下 : 


<?php 
$conn=mysql_connect ("localhost", "root","") or die ("数据 库 服 务 器 连接 
错误 ".mysql_error()); 
// 设 置 数 据 库 连接 , 本 地 服务 器 ,用 户 名 为 root ,密码 为 空 , 如 果 连 接 错 误 调用 mysql_error () 
mysql_select db ("db_shop", $conn) or die ("数据 库 访 问 错误 " .mysql_ 
error()); 
// 连 接 db_shop 数 据 库 ， 如 果 连 接 错误 调用 mysql_error ()。 
mysql_ query("set character set gb2312"); 
mysql query("set names gb2312"); 


- 320 - 


// 设 置 数据 库 的 字体 为 gb2312 即 中 文 简体 。 
?> 


读者 使 用 时 如 果 需 要 更 改 数据 库 名 称 , 只 需要 将 该 页 面 中 的 db_shop 做 相应 的 更 改 即 可 
以 实现 ， 同 时 也 要 使 用 户 名 和 密码 与 你 在 本 地 安装 的 用 户 名 和 密码 一 样 。 


9.3 ”首页 动态 功能 开发 


对 于 一 个 电子 商城 系统 来 说 ， 需 要 一 个 主页 面 来 给 用 户 进行 注册 、 搜 索 需要 定购 的 商 
品 、 网 上 浏览 商品 等 操作 ,实例 首页 index.php 主 要 榜 套 了 由 font.css、 top.php、 left_ menu.php、 
bottom.php 等 共 5 个 页 面 组 合 而 成 ， 本 小 节 介 绍 这 些 页 面 的 设计 过 程 。 


< 9.3.1 ) 创 建 样式 表 

任何 网 站 如 果 想 看 上 去 美观 些 都 是 要 经 过 专业 的 网 页 布局 设计 的 ， 实 例 按 传统 的 电子 
商务 网 站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样 
式 表 保存 在 css 文 件 夹 下 。 

国 运行 Dreamweaver CC 软件 ， 打 开 制 作 到 这 一 步骤 的 站 点 文件 夹 。 执 行 菜单 栏 “ 文 
件 ” 一 “新 建 ”命令 ， 打 开 “ 新 建文 档 ” 对 话 框 ， 选 择 “空白 页 ”选项 卡 中 “页 面 类 型 ” 
下 拉 列 表 框 下 的 CSS， 然 后 单 击 “ 创 建 ”按钮 创建 新 页 面 ， 如 图 9-25 所 示 。 在 网 站 css 目 录 
下 新 建 一 个 名 为 font.css 的 网 页 并 保存 。 
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图 9-25 创建 css 文 件 
加 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 


Aslin 
COLOR: #990000; 
TEXT-DECORATION: none 
} 
A:visited { 
COLOR: #990000; TEXT-DECORATION: none 
} 
A:active { 
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SS @De 


COLOR: #990000; TEXT-DECORRTION : none 
A:hover { 
COLOR: #000000 


} 
// 网 页 链接 属性 设置 
BODY { 


margin-top: Opx; 

} 

TD,TH { 

FONT-SIZE:12px; 

COLOR: #000000; 

} 

.buttoncss { 
font-family: "Tahoma"，" 宋 体 "; 
font-size: 9pt; color: #003399; 
border: lpx #fff solid; 
color:006699; 
BORDER-BOTTOM: #93bee2 lpx solid; 
BORDER-LEFT: #93bee2 lpx solid; 
BORDER-RIGHT: #93bee2 lpx solid; 
BORDER-TOP: #93bee2 lpx solid; 
background-color: #ccc; 
CURSOR: hand; 
font-style: normal ; 

} 

-inputcss { 
font-size: 9pt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border-color: #93BEE2 #93BEE2 #93BEE2 #93BEE2 ; 
border: lpx #93BEE2 solid; 

} 

.inputcssnull { 
font-size: 9pt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border: Opx #93BEE2 solid; 

} 

.Scrollbart{ 
SCROLLBAR-FACE-COLOR: #FFDD22; 
FONT-SIZE: 9pt; 
SCROLLBRR-HIGHLIGHT-COLOR : #69BC2C; 
SCROLLBAR-SHADOW-COLOR: #69BC2C; 
SCROLLBAR-3DLIGHT-COLOR: #69BC2C; 
SCROLLBRR-ARROW-COLOR : #£ffffff; 
SCROLLBAR-TRACK-COLOR: #69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


} 

.Scrollbart{ 
SCROLLBAR-FACE-COLOR: #FFDD22; 
FONT-SIZE: 9pt; 
SCROLLBRR-HIGHLIGHT-COLOR : #69BC2C; 
SCROLLBAR-SHADOW-COLOR: #69BC2C; 
SCROLLBAR-3DLIGHT-COLOR: #69BC2C; 
SCROLLBAR-ARROW-COLOR: #£fffff; 
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SCROLLBAR-TRACK-COLOR: #69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


} 
// 网 页 表单 对 象 的 样式 设置 
通过 上 面 样式 文件 的 建立 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 
人 9.3.2 ) 设 计 网 站 导航 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 常情 况 下 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 
型 一 点 的 可 能 会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 
或 者 需要 更 改 的 时 候 ， 这 个 工作 量 就 会 变 得 很 大 ， 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开发 
成 单独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调用 它 。 这 样 当 需要 变更 的 时 候 ， 只 要 修改 导 
航 栏 这 一 个 页 面 , 其 他 的 页 面 自动 就 全 部 更 新 了 。 实例 创建 的 带 显示 登录 用 户 名 的 导航 栏 ， 
如 图 9-26 所 示 。 


隔 360 安 全 浏 砚 医 7.1 票 单 首 一 口 x 
《人 二 会 太 加 127.0.0.1 BEY 
电子 商务 网 站 ~ al a 


图 9-26 导航 频道 

这 里 制作 的 步骤 如 下 : 

加 在 Dreamweaver CC 中 执行 菜单 栏 “文件 ” 一“ 新建 ”命令 ， 打 开 “ 新 建文 档 ” 对 
话 框 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 下 的 PHP 选 项 ， 在 “布局 ”下 拉 
列表 框 中 选择 “无 ”选项 ， 然 后 单 击 “ 创 建 ”按钮 创建 新 页 面 ， 在 网 站 根 目 录 下 新 建 一 个 
名 为 top.php 的 网 页 并 保存 。 

再 单 击 “ 显 示 代 码 视图 ”[ 回 贻 | 按钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创 
建 代码 删除 ， 然 后 加 入 如 下 代码 : 


<?PhP 
session start(); 
include ("conn/conn.php"); 
?>// 调 用 session 函 数 ， 并 调用 conn .php 数 据 库 链接 文件 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 电 子 商 务 网 站 </title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<body> 
<table width="766" border="0" align="center" cellpadding="0" 
cellspacing="0" background="images/bannerdi.gif"> 
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< 

<td colspan="3" valign="bottom"><table width="766" border="0" 
align="center" cellpadding="0" cellspacing="0"> 

KE 

<td width="224" height="83">g&nbsp;</td> 

<td align="right"><p>&nbsp;</p> 

<table height="20" border="0" align="center" cellpadding="0" 
cellspacing="0"> 

</table></td> 

</tr> 

</table></td> 

</tr> 

< 

<td width="568" height="32" bgcolor="#FFFFFF">&nbsp; &nbsp;é&nbsp; 
&nbsp; gnbsp;<a href="index.php"> 首 页 </a>gnbsp;| <a 
href="shownewpr .php"> 最 新 婚纱 </a> | <a href="showtuijian. 
Php"> 推 荐 品牌 </a> | <a href="showhot.php"> 热 门 品 牌 </a>&nbsp; |&nbsp;<a 
href="showfenlei .php"> 婚 纱 分 类 </a>&nbsp; |&nbsp;<a href="usercenter.php"> 
用 户 中 心 </a>&gnbsp; |&gnbsp;<a href="finddd.php"> 订 单 查询 </a>&nbsp; |&nbsp;<a 
href="gouwuche .php"> 购 物 车 </a></td> 

<td width="121" align="center" bgcolor="#FFFFFF"> 

</td> 
<HEr> 
</table> 


上 述 代 码 中 加 黑 部 分 为 用 户 中 心 ， 可 以 方便 用 户 登录 购物 显示 购物 车 的 详细 信息 ， 也 
可 以 让 用 户 注销 离开 。 


辆 加 入 代码 后 ， 这 时 就 会 发 现在 编辑 文档 窗口 中 的 效果 ， 具 体 如 图 9-27 所 示 。 
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图 9-27 自动 生成 代码 占 位 符 


最 后 保存 制作 的 页 面 ， 按 F12 快 捷 键 ， 即 可 以 在 正 浏览 器 中 看 到 和 原来 一 样 的 导航 效 
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left_ menu.php 页 面 中 的 “我 的 购物 车 ”、“ 用 户 系统 ”、“ 站 内 搜索 ”3 个 栏目 是 动态 
网 站 开发 中 经 常 遇 到 的 功能 ， 在 电子 商城 中 这 几 个 功能 也 是 必 不 可 少 的 ， 下 面 将 详细 介绍 
这 些 功能 的 开通 办 法 ， 制 作 步 又 如 下 : 


为 了 能 够 实现 页 面 的 调用 ， 需 要 首先 打开 数据 库 db_shop 文 件 ， 然 后 再 打开 
tb_gonggao 数 据 表 ， 加 入 一 些 数据 ， 如 图 9-28 所 示 。 


= 


[FE EE 3 


€ [©) A |#|| ®t /2 00 Vpnpmyadmin/ PMALAL Zs9l php7db=db shopatable=tbh gongganaserver=atarqet-E 区 四 


钢 属 凶 吉 伸 司 几许 34 核心 得 示 : 价格 俯 廊 的 姐 钞 铭 套 委 现 状 有 请 票 ， 介 是 
Ee TN 
NW 重 对 不 同 岂 档 、 不 同 从 和、 不 月 规 苇 的 将 礼 备 选 场地 ， 怎 

ba 银 老 
后 o 全 时 和 丰 刘 图 抽 洲 到 要 信 息 六 大 可 芋 寺中 |。 名 计生 慢 ; 坊 并 东 订 蛙 罕 喜 放 防 韦 儿 ， 户 小 有 人 会 各 它 和 
2 南欧 全 障 二 关于。 可 全 天 上 于 1 点 双 ， 一 本 从 请 开 
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图 9-28 加 入 数据 信息 
创建 left_ menu.php 页 面 ， 然 后 在 <head> 代 码 之 前 ， 加 入 调用 数据 库 链 接 页 面 
conn.php 的 命令 ， 如 下 : 
<zphp include("Conn/conn.Php")j?> 


我 的 购物 车 主要 实现 登录 后 能 显示 登录 的 用 户 名 ， 并 显示 购物 车 的 实时 情况 ， 实 现 的 
PHP 代 码 如 下 : 
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//session register("total"); 
if($ GET[qk]=="yes"){ 
$_SESSION [producelist]=""; 
$_SESSION[quatity]=""; 
} 
$arraygwc=explode("@",$_ SESSION[producelist]); 
$s=0; 
for ($i=0; $i<count ($arraygwc); $i++) { 
$s+=intval ($arraygwc [$i]); 
} 
if($s==0 ){ 
echo "<tr>"y 
echo"” gnbsp;&nbsp; 您 的 购物 车 为 空 !"; 
echo"</tr>"; 
} 
elsef 
> 
<?php 
$total=0; 
$array=explode ("@",$_SESSION[producelist]); 
$arrayquatity=explode("@",$_SESSION [quatity]); 
while (list ($name, $value)=each($ POST)){ 
for($i=0;$i<count ($array) -1;$i++) { 
if( ($array[$i])==$name){ 
$arrayquatity[$i]=$value; 
E 
} 
} 
$_SESSION [quatity]=implode ("@", $arrayquatity); 


for($i=0;$i<count ($array) -1; $i++) { 
$id=$array[$i]; 
$num=$arrayquatity[$i]; 


if ($id!=""){ 

$sql=mysql_ query("select * from tb shangpin where 
id='".$id."'",$conn); 

$info=mysql_fetch array($sql); 

$totall=$num*$info[huiyuanjia]; 

$total+=$totall; 

$_SESSION["total"]=$total; 


> 
&nbsp; 
<?php 
} 
} 
?> 
购物 车 总 计 : <?php echo $total;?> 元 
<br> 


&nbsp; &nbsp;<a href="gouwusuan.php"> 去 收银 台 </a> <a 
href="gouwuche .php?qk=yes"> 清 空 购物 车 </a> 
<?php 
} 
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3> 
<?php 
if($_SESSION[username] !=""){ 
echo "gnbsp; Enbsp;<a href='1logout .php'> 注 销 离 开 </a>"; 
} 


?></br> 
</tad> 
</tr> 
</form> 
</table> 
然后 简单 地 设计 一 下 功能 的 显示 效果 ， 设 计 完 成 后 编辑 文档 窗口 ， 如 图 9-29 所 示 。 


总 docs\shopVeft_menu.php 本 [< ; 


图 9-29 设计 我 的 购物 车 
加 在 “用 户 系 统 ”的 显示 界面 上 ， 是 提供 给 用 户 登 录 、 注 册 以 及 找 回 密码 的 功能 ， 
具体 的 注册 和 找 回 密码 的 功能 将 在 下 一 节 介 绍 ， 这 里 重点 介绍 使 用 PHP 实 现 验 证 码 随 机 调 
用 并 显示 成 数字 的 功能 ， 程 序 如 下 : 
<?php 


$num=intval (mt_rand (1000, 9999) ) 


// 使 用 到 了 mt_rand () 函数 调用 介 于 1000-9999 的 任意 一 个 数字 。 
for ($i=0; $i<4; $i++) { 
echo "<img src=images/code/" .substr(strval ($num), $i,1).".gif>"; 


} 
// 调 用 images/code/ 文 件 夹 下 的 随机 字母 图 片 ， 并 显示 成 4 位 数 。 
D> 


该 程序 能 够 实现 如 图 9-30 所 示 的 随机 显示 图 片 验 证 码 数字 的 效果 。 


i 


用 户 : 
密码 : 
验 证 : 1972 


图 到 注册 找 回 密码 
图 9-30 ”显示 验证 码 效果 
加 用 户 输入 用 户 名 和 密码 , 并 单 击 “ 登 录 ” 按 钮 后 , 要 将 输入 的 数据 传递 到 chkuserphp 
页 面 进行 登录 验证 。 代 码 如 下 : 


<form name=" form2" method="post" action="chkuser.php" onSubmit="return 
chkuserinput (this)"> 


- 327 - 


( “ee。 


en 网 站 开发 全 程 实例 (第 2 版 ) 


该 段 代 码 包 含 了 两 个 意思 ， 第 一 个 action="chkuser.php" 意 思 是 ， 转 到 chkuser.php 页 面 
进行 验证 ; 第 二 个 onSubmit="returm chkuserinput(this)" 意 思 是 直接 调用 JavaScript 的 
chkuserinput(this) 进 行 数据 输入 的 验证 , 即 通 常 在 提交 表单 时 要 验证 一 下 输入 的 数据 是 否 为 
空 ， 输 入 的 数据 格式 是 否 符 合 要 求 ， 调 用 的 程序 如 下 : 


<script language="javascript"> 
function chkuserinput (form){ 
if(form.username.value==""){ 
alert ("请 输入 用 户 名 !"); 
form.username.select() 7 
return (false) 
了 // 如 果 用 户 名 没 输入 提示 “请 输入 用 户 名 ! “ 
if (form.userpwd.value==""){ 
alert ("请 输入 用 户 密码 !"); 
form.userpwd.select (); 
return (false); 
1 // 如 果 用 户 密码 没 输 入 提示 “请 输入 用 户 密码 二 
if (form.yz.value==""){ 
alert ("请 输入 验证 码 !"); 
form.yz.select (); 
return (false); 
} // 如 果 用 户 验 证 码 没 有 输入 提示 “请 输入 验证 码 !” 
return (true); 


} 


</script> 
加 在 主页 的 “品牌 新 闻 ” 显 示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 
时 能 打开 详细 页 面 ， 调 出 5 条 所 有 的 数据 并 将 所 有 的 代码 列 出 ， 说 明 如 下 : 
<?php 


$sql=mysql_query ("select * from tb gonggao order by time desc limit 
0,5",$conn); 


// 按 时 间 顺 序 从 tb_gonggao 数 据 表 中 调用 5 条 数据 
$info=mysql fetch array ($sql); 
if ($info==false){ 

人 > 
i 
<td height="20" align="center"> 暂 无 新 闻 公 告 !</td> 
</tr>// 如 果 没 有 数据 则 显示 为 “ 暂 无 新 闻 公告 ! “ 


<?PhP 
} 
else{ 
dof 
> 
<tr> 
<td height="20"><div align="center"> 
<table width="180" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td width="16" height="5"><div align="center"><img 
src="images/circle.gif" width="11" height="12"></div></td> 
<td width="164" height="24"><div align="]left"> <a 
href="gonggao.php?id=<?php echo $info[id];?>"> 
<?php 
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echo substr($info[title],0,24); 
if(strlen(S$info[title]l)>24) 1{ 
Seno Te 


} // 调 用 新 闻 标 题 并 控制 显示 的 字符 数 为 24， 如 果 标题 比较 长 则 显示 为 . - 
?> 


</a> </div></td> 

</tr> 

</table> 

</div></td> 

</tr> 

<?php 

} 

while ($info=mysql fetch array ($sql)); 
} 

?> 


四 在 IE 浏览 器 中 浏览 制作 的 调用 数据 ， 效 果 如 图 9-31 所 示 。 

品牌 新 闻 : 更 多 . 
» 低 价 婚纱 照 背 后 的 问题 
高 房价 与 “ 隔 代 结婚 ” 
» 如 寞 场地 简单 10 步 轻松 接 定 
» 瑞典 新 郎 礼服 典雅 简约 不 失 精 至 
» 警惕 婚礼 大 客车 途中 发 生 的 故障 
» 种 玫瑰 发 短信 高 站 戒 参 与 须知 
新 娘 要 “ 牵 子 成 婚 ” 首选 待产 新 娘 


MBE 
如 此 轻易 的 就 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 发 现 PHP 动 态 网 页 的 开发 并 不 
是 很 难 ， 只 需要 掌握 简单 的 代码 即 可 以 实现 。 在 下 面 的 所 有 其 他 功能 区 域 都 是 采用 调用 、 条 件 
查询 、 绑 定 显 示 、 关 闭 数据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 


图 9-31 “品牌 新 闻 ” 的 效果 


最 下 面 的 “站 内 搜索 ”功能 开发 是 将 查询 文本 框 放置 到 一 个 表单 内 ， 在 单 击 “ 搜 
索 ” 时 提交 到 serchorderphp 页 面 进行 搜索 并 显示 结果 页 面 ， 单 击 “ 高 级 ”按钮 时 提交 到 
highsearch.php 页 面 进行 高 级 的 搜索 ， 该 程序 主要 嵌入 在 <form> 表 单 之 内 ， 代 码 如 下 : 


<form name="form" method="post" action="serchorder.php"> 


<tr 
<td width="500" height="30" valign="middle"><div align="center"> 
<input TYPe=" text" name="name" size="15" class="inputcss" 


style="background-color:#fff 
onMouseOver="this.style.backgroundColor="'#£ffffff"'" 
onMouseOut="this.style.backgroundColor='#e8f4ff"'"> 

<input type="hidden" name="jdcz" value="jdcz"> 

<input name="submit" type="submit" class="buttoncss" value=" 搜 索 "> 


<input name="button™" type="button" class="buttoncss" 
onClick="javascript :window.location='highsearch.php';"” value=" 高 级 "> 
</div></td> 
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</tr> 
</form> 


此 时 Left_meau.php 页 面 和 新 闻 模 块 就 开发 完毕 了 ， 保 存 以 方便 其 他 页 面 嵌 套 使 用 。 
-534 ) 产 品 的 前 台 展 示 

网 站 实现 在 线 购物 ， 一 般 都 是 通过 用 户 自 身 的 登录 、 浏 览 、 定 购 、 结 算 这 样 的 流程 来 
实现 网 上 购物 的 ， 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 的 重要 ， 实 例 在 首页 上 设计 
了 “推荐 品牌 ”、“ 最 新 婚纱 ”以 及 “热门 品牌 ”三 个 显示 区 域 ， 下 面 就 介绍 产品 展示 区 
域 的 实现 方法 。 

贺 对 于 上 述 的 三 个 显示 区 域 在 使 用 程序 开发 之 前 ， 首 先 要 先 在 Dreamweaver CC 中 设 
计 好 最 终 的 网 页 效果 ， 实 例 设计 的 三 个 展示 区 域 如 图 9-32 所 示 ， 每 个 区 域 显示 最 新 发 布 的 
两 款 产品 信息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “详细 ” 
的 按钮 。 


Dw mn WH sm mAD Pam WO) 3999 me em som mm. Ca Ol-lel*] 
上 此 
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图 9-32 设计 产品 展示 的 区 域 效果 
加 三 个 区 域 的 程序 实现 的 方法 是 一 样 的 , 就 是 按 条 件 查 询 出 数据 的 结果 是 不 一 样 的 ， 
这 里 介绍 “推荐 品牌 ”区 域 的 代码 实现 方法 如 下 : 


<table width="550" border="00" align="center™" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td width="555" height="110"><table width="530" height="110" border="0" 
align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="265"> 
<?php 
$sql=mysql_query("select * from tb shangpin where tuijian=]1 order by 
addtime desc 1imit 0,1");// 按 tujian=1 的 值 调用 数据 
$info=mysql fetch array($sql); 
if($info==false){ 
echo "本 站 暂 无 推荐 商品 !"; 
}// 如 果 没 有 数据 显示 为 "本 站 暂 无 推荐 商品 !" 
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elset 
2% 
<table width="270" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if (trim($info[tupian]=="")){ 
echo " 暂 无 图 片 "; 
}/ /如果 没 有 产品 图 片 则 显示 为 " 暂 无 图 片 " 
elsef 
人 
<img src="<?php echo S$info[tupian];?>" width="80" height="80" 
border="0"> 
<?php 
; 
人 
</div></td> 
<td width="11" height="16">&nbsp;</td> 
<td width="124"><font color="FF6501"><img src="images/circle.gif" 
width="10" height="10">gnbsp;<?php echo $info[mingcheng];?></font></td> 
= 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="#000000"> 市 场 价 : </font><font color="FF6501"><?php echo 
$info[shichangjia];?></font></td> 
</tr> 
<tr> 
<td height="16">gnbsp;</td> 
<td><font color="#000000"> 会 员 价 :</font><font color="FF6501"><?php echo 
$info[huiyuanjia];?></font></td> 
</tr> 
EE 
<td height="16">&nbsp;</td> 
<td><font color="#000000"> 剩余 数量 : </font><font color="13589B"> 
<?php 
if($info[shuliang]>0) 
{ 
echo $info[shuliang]; 
} 
else 
{ 
echo "已 售 完 "; 
} 
?> 
</font></td> 
eT 
<Er> 
<td height="30" colspan="2"><a href="lookinfo.php?id=<?php echo 
$info[id];?>"><img src="images/b3.gif" width="34" height="15" 
border="0"></a> <a href="addgouwuche .php?id=<?php echo $info[id];?>"><img 
src="images/bl .gif" width="50" height="15" border="0"></a> </td> 
«E> 
</table> 
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?> 
</td> 

<td width="265"> 

<?php 

$sql=mysql query("select * from tb shangpin where tuijian=]1 order by 
addtime desc limit 1,1"); 

$info=mysql fetch array($sql); 

if($info==true) 

{ 


人 了 之 

<table width="270" border="0" cellspacing="0" cellpadding="0"> 
SE 

<td width="130" rowspan="5"><div align="center"> 

<?php 


if (trim($info[tupian]=="")){ 
echo " 暂 无 图 片 "; 
} 
else{ 
六 
<img src="<?php echo S$info[tupian];?>" width="80" height="80" 
border="0"> 
<?php 
} 
> 
</div></td> 
<td width="11" height="16">&nbsp;</td> 
<td width="124"><font color="FF6501"><img src="images/circle.gif" 
width="10" height="10">gnbsp;<?php echo $info[lmingcheng];?></font></td> 
<Itr> 
区 区 
<td height="16">&nbsp;</td> 
<td><font color="#000000"> 市 场 价 :</font><font color="FF6501"><?php echo 
$info[shichangjia];?></font></td> 
</ tr> 
<tr> 
<td height="16">&nbsp;</td> 
<td><font color="#000000"> 会 员 价 :</font><font color="FF6501"><?php echo 
$info[huiyuanjia];?></font></td> 
</tr> 
< 
<td height="16">gnbsp;</td> 
<td><font color="#000000"> 剩 余数 量 : </font><font color="13589B"> 
<?php 
if($info[shuliang]>0) 
{ 
echo $info[shuliang]; 
} 
else 
t 
echo "已 售 完 "; 
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“eee 
> 
</font></td> 
</tr> 
<tE> 
<td height="30" colspan="2"><a href="]lookinfo.php?id=<?php echo 
$info[id];?>"><img src="images/b3.gif" width="34" height="15" 


border="0"></a> <a href="addgouwuche .php?id=<?php echo $info[id];?>"><img 
src="images/bl .gif" width="50" height="15" border="0"></a> </td> 

</tr> 

</table> 

<?php 
} 

</td> 

</tr> 

</table></td> 

</tr> 

< 

<td height="10" background="images/linel.gif"></td> 

</tr> 

</table> 


园 按 上 述 的 程序 实现 方法 ， 将 另外 两 个 产品 展示 的 功能 设计 完成 ， 最 后 可 以 实现 的 
效果 如 图 9-33 所 示 。 


sn 71 Rm Wx 

后 | 信介 太 | 回 127.0.0.1 BOY 

PD =a - 国 | 
验证 | 1972 。 失 Be 更 有 


Rf ED “8 


MR 玄 如 部; 四 


图 9-33 首页 的 商品 展示 效果 


多 9.3.5 ) 版 权 页 面 


底部 版 权 页 面 是 一 个 静态 的 页 面 , 制作 非常 的 简单 ， 在 Dreamweaver CC 中 进行 直接 排 
版 设计 即 可 ， 完 成 的 效果 如 图 9-34 所 示 。 
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示 cwampp\htdocs\shop\bottom php 站 


首 页 | 企业 简介 | 加 点 连 镜 | 招聘 岗位 | 联系 我 们 


加 


Copyight © 1998-2013 www.jadebridal com. All rights reserved. 


上 回电 735 x 110v 


图 9-34 版 权 页 面 的 效果 
网 站 的 首页 制作 结束 ， 如 果 需 要 快速 建立 首页 ， 可 以 直接 参考 网 上 下 载 资源 中 完成 的 
页 面 ， 查 看 代码 ， 可 以 方便 地 完成 购物 系统 首页 的 设计 与 制作 。 


2 9.4 会 员 管理 系统 功能 


网 站 的 会 员 管 理 系统 ， 在 首页 上 只 是 一 个 让 用 户 登 录 和 注册 的 窗口 。 当 输入 用 户 名 和 
密码 时 ， 单 击 “ 登 录 ” 按 钮 ， 即 转 到 chkuserphp 页 面 进行 判断 登录 。 当 单 击 “ 注 册 ” 文 字 
链接 时 ， 将 会 打开 网 站 的 会 员 注 册页 面 agreereg.php 进 行 注 册 。 单 击 “ 找 回 密码 ”会 弹出 找 
回 密码 的 Windows 对 话 窗口 ， 本 小 节 将 对 会 员 管理 系统 的 开发 进行 介绍 。 


541 ) 会 员 登 录 判断 


会 员 在 首页 输入 用 户 名 和 密码 ， 单 击 “ 登 录 ” 按 钮 时 只 有 用 户 名 、 密 码 、 验 证 码 全 部 
正确 才 可 以 登录 成 功 ， 如 果 有 错误 就 需要 显示 相关 的 错误 信息 ， 所 有 的 功能 都 要 用 PHP 进 
行 分 析 判 断 ， 创 建 一 个 空白 PHP 页 面 ， 并 命名 为 chkuser.php。 

在 该 页 面 中 加 入 如 下 的 代码 : 


<?php 
include ("conn/conn .php");// 调 用 数据 库 连 接 
$username=$_POST[username]; 
$userpwd=md5($_POST[userpwd]); 
$yz=$_POST [yz]; 
$num=$_POST[num]; 
if(strval ($yz) !=strval (Snum) ) { 
echo "<script>alert (' 验 证 码 输 入 错误 !');history.go(-1);</script>"; 
exit; 
}// 如 果 验 证 码 错误 则 提示 “验证 码 输入 错误 !”， 并 且 返 回 登 录 页 面 
class chkinput{ 
Var $name; 
Var S$pwd; 
function chkinput ($x,$y){ 
$this->name=$x; 
$this->pwd=$y; 


} 

function checkinput (){ 

include ("conn/conn.php"); 
$sql=mysql_query ("select * from tb user where 

name="'".$this->name."'", $conn); 
$info=mysql fetch array ($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 不 存在 此 用 户 ! 
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exit7 
}// 如 果 数 据 库 里 不 存在 该 用 户 名 则 显示 “不 存在 此 用 户 ”， 并 返回 。 
elsef{ 


if($info[ldongjie]==1){ 
echo "<script language='javascript'>alert(' 该 用 户 已 经 被 冻结 ! 
');history.back();</script>"; 
exit; 
}// 如 果 用 户 已 经 在 后 人 台 冻 结 ， 则 显示 “该 用 户 已 经 被 冻结 ! ”并 且 返 回 
if ($info[pwd]==$this->pwd) 
{ 
session start(); 
$_SESSION[username]=$info[name]; 
session register("producelist"); 
$producelist=""; 
session register ("quatity"); 
$quatity=""; 
header ("location:index.php"); 
exit; 
: 
else { 
echo "<script language='javascript'>alert(' 密码 输入 错误 ! 
') ;history.back();</script>"; 
exit; 


}// 如 果 用 户 密码 错误 ， 则 显示 “密码 输入 错误 ! ”并 且 返 回 


$obj=new chkinput (trim(S$Susername) ,trim($userpwd)); 
S$obj ->checkinput() > 

?> 

该 段 程序， 首先 加 入 判断 验证 码 、 用 户 名 以 及 密码 是 否 正 确 的 代码 ， 如 果 不 正确 则 显 
示 相 应 的 错误 信息 ， 如 果 全 部 正确 则 登录 成 功 返 回 登 录 的 首页 。 

和 542) 会 员 注 册 功能 

会 员 注册 的 功能 并 不 只 是 简单 的 一 个 网 页 就 能 实现 ， 它 需要 同意 协议 ， 判 断 用 户 是 否 
存在 ， 写 入 数据 等 细节 的 步骤 ， 这 里 介绍 如 下 : 

加 单 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注册 页 面 agreereg.php， 该 页 面 制 
作 的 效果 如 图 9-35 所 示 。 该 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 一 下 网 站 管理 者 ， 为 了 避免 日 
后 注册 用 户 会 发 生 一 些 纠纷 ， 需 要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 放 到 注册 信息 里 
面 ， 这 样 可 以 有 效 地 保护 自己 的 利益 。 
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函 cvamppwtdocssnopugreeeg pnp -DX 


图 9-35 ”同意 网 站 里 的 服务 条 款 
贺 单 击 “ 同 意 ” 按 钮 后 ， 就 打开 具体 的 注册 用 户 信息 填写 内 容 页 ， 该 页 面 制作 的 时 
候 也 比较 简单 ， 只 需要 按 数 据 库 中 tb_user 数 据 表 的 字段 名 为 准 ， 在 注册 页 面 分 别 创建 相应 
的 文本 框 即 可 ， 设 计 的 页 面 如 图 9-36 所 示 。 


动 cvampp\ntdocsisnopveg php -Ox 
IW top php etto pz 


> Vor CE 


图 9-36 用 户 注册 信息 的 页 面 


其 中 的 技术 难点 在 于 “查看 昵称 是 否 已 用 ”功能 ， 在 输入 用 户 昵称 时 ， 需 要 单 击 
该 按钮 检查 数据 库 中 是 否 有 存在 该 用 户 昵 称 ， 实 现 的 方法 代码 如 下 : 
<script language="javascript"> 
function chknc (nc) 
{ 
window.open("chkusernc.php?nc="+nc,"newframe","width=200,height=10,1 
eft=500, top=200,menubar=no, toolbar=no, location=no, scrollbars=no,1locatio 
n=no"); 
}// 单 独 打开 Windows 窗 口 通 过 调用 chkusernc .php 页 面 进行 判断 


</script> 


所 以 左 套 的 实际 判断 的 页 面 是 chkusemc.php， 该 页 面 的 代码 如 下 : 
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在 单 击 “ 提 交 ” 按 钮 时 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 的 JavaScript 程 序 进行 
检查 的 代码 如 下 : 
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if (form.usernc.value=="") 


alert ("请 输入 昵称 !"); 
form.usernc.select (); 
return (false); 
} 
if(form.pl.value=="") 
{ 
alert ("请 输入 注册 密码 !"); 
form.pl.select (); 
return (false); 
} 
if (form.p2.value=="") 
f 
alert ("请 输入 确认 密码 !"); 
form.p2.select (); 
return (false); 
} 
if(form.pl.value.length<6) 
{ 
alert ("注册 密码 长 度 应 大 于 6!"); 
form.pl.select (); 
return (false); 
} 
if(form.pl.value!=form.p2.value) 
上 
alert ("密码 与 重复 密码 不 同 !"); 
form.pl.select (); 
return (false); 
} 
if(form.email .value=="" 
{ 
alert ("请 输入 电子 邮箱 地 址 !"); 
form.email.select(); 
return (false); 
} 
if(form.email .value.indexOf('@')<0) 
{ 
alert ("请 输入 正确 的 电子 邮箱 地 址 !"); 
form.email.select(); 
return (false); 
} 
if(form.tel.value=="") 
{ 
alert ("请 输入 联系 电话 !")， 
form.tel .select (); 
return (false); 
} 
if(form.truename .value=="") 
{ 
alert ("请 输入 真实 姓名 !")，; 
form.truename.select (); 
return (false); 
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该 段 程序 是 验证 表单 经 常 使 用 到 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 对 于 其 他 
系统 的 开发 也 经 常 使 用 到 。 


在 验证 表单 没 问 题 后 ， 才 将 表单 的 数据 传递 到 savereg.php 页 面 进行 数据 表 的 插入 
记录 操作 ， 也 就 是 实质 上 的 保存 用 户 注册 信息 的 操作 ， 具 体 的 代码 如 下 : 


daa 网 站 开 失 全程 实例 (第 2 版 ) 


} 
$huida=$_ POST[tsdal; 
$dizhi=$_POST[dizhi]; 
$youbian=$ POST[yb]; 
$regtime=date ("Y-m-j"); 
$dongjie=0; 
$sql=mysql_ query("select * fromtb user where name='".S$name."'",$conn); 
$info=mysql fetch array ($sql); 
if ($info==true) 

{ 

echo "<script>alert (' 该 昵称 已 经 存在 !') ;history.back();</script>"; 


exit; 
} 
else 
{ 
mysql query("insert into tb user 
(name, pwd, dongjie,email,truename, sfzh,tel,qq,tishi,huida, 
dizhi,youbian,regtime,pwd]l) values 


('$name','$pwd', '$dongjie', '$email','$truename', '$sfzh','s$tel', 

'$qq', '$tishi', '$huida','$dizhi','S$youbian', '$regtime', '$pwdl1l')",S$co 
nn) ;// 按 字段 对 应 相应 的 数据 

session register ("username"); 

$username=$name; 

session register("producelist"); 

$producelist=""; 

session register ("quatity"); 

$quatity=""; 

echo "<script>alert(' 恭 喜 ， 注 册 成 
功 !') ;window.location='index.php';</script>"; 


}1// 插 入 数据 后 显示 注册 成 功 ， 并 返回 首页 index .php 

?> 

通过 以 上 几 个 步骤 的 程序 编写 才 完成 一 个 会 员 注册 的 功能 ， 一 般 的 用 户 注册 都 是 这 样 
的 一 个 逻辑 实现 过 程 。 

放 9.4.3 ) 找 回 密码 功能 

会 员 在 使 用 过 程 中 忘记 密码 也 是 经 常 遇 到 的 事 ， 在 实例 中 单 击 “ 找 回 密码 ”文字 链接 
将 打开 相应 的 窗口 实现 找 回 密码 的 功能 ， 具 体 的 实现 步骤 如 下 : 

加 在 制作 的 left_men.php 页 面 中 加 入 Javascript 的 验证 代码 ， 实 现 的 功能 是 单 击 “ 找 回 
密码 ”链接 时 打开 openfindpwd.php 页 面 进 行 验证 ， 代 码 如 下 : 


<script language="javascript"> 
function openfindpwd (){ 
window.open ("openfindpwd.php","newframe","]left=200,top=200,width=200 
:height=100,menubar=no,toolbar=no,location=no,scrollbars=no,1location=no 
Se 
} 
</script> 


因 使 用 Dreamweaver 设 计 出 找 回 密码 的 页 面 如 图 9-37 所 示 , 只 需要 一 个 简单 的 对 话 窗 
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口 ， 输入 昵称 并 进行 判断 即 可 。 


函 Cxampp\htdocs\shop\openfindpwd.php 
HIRED font. css 


I? body 目 目 国 330 x 108v 
图 9-37” 找 回 密码 的 页 面 


加 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ” 按 钮 需要 进行 表单 验证 ， 判 断 是 
否 为 空 ， 如 果 不 为 空 则 指向 findpwd.php 页 面 显示 “密码 提示 ”, 输入 提示 的 答案 ， 如 图 9-38 
所 示 。 


<script language="javascript"> 

function chkinput (form) 
{ 

if(form.nc.value=="" 

{ 

alert (" 请 输入 您 的 昵称 !") ; 
form.nc.select (); 
return(false); 


} 
return (true); 
} 
</script 


画 cvemppwtdocsshopvindpwdphp _ 
4 本》 funt ss con php 


3” body 目 目 呢 333 x ii6v 
图 9-38 密码 提示 页 面 
国 输入 “提示 答案 ”之 后 ， 单 击 “ 确 定 ”按钮 ， 也 要 进行 表单 验证 并 转向 最 终 显示 
密码 的 页 面 showpwd.php， 验 证 的 代码 如 下 : 
<script language="javascript"> 
function chkinput (form) 
if(form.da.value=="") 


. 
alert (' 请 输入 密码 提示 答案 !'); 


= 
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form.da.select (); 
return (false); 


} 
return (true); 
} 
</script> 
<form name="form2" method="post" action="showpwd .php" 


onSubmit="return chkinput (this)"> 


加 showpwd.php 的 页 面 比较 简单 只 需要 查询 数据 库 ， 把 符合 条 件 的 数据 显示 出 结果 ， 
即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-39 所 示 。 


示 cvwampp\htdocs\shop\showpwd php 


人 font. ess conn php 


Zi 目 313 x 108v 


图 9-39 显示 密码 页 面 


9.5 “ 品牌 新 闻 系统 

网 站 的 “品牌 新 闻 ” 在 首页 及 各 个 页 面 显示 了 标题 ， 当 单 击 相应 的 标题 时 ， 将 打开 详 
细 的 显示 内 容 页 面 gonggao.php， gonggao.php 用 于 显示 具体 的 信息 内 容 ; 当 单 击 首页 的 “更 
多 >>” 文 字 链 接 时 ， 即 可 打开 所 有 的 信息 标题 页 面 gonggaolist.php。 
557 ) 信 息 标题 列表 

所 有 的 信息 标题 页 面 gonggaolist.php 制 作 的 效果 ， 如 图 9-40 所 示 。 


示 campp\htdocs\shop\gonggaolist php -Ox 
OSD top php left_nens php botton php 了 


幸福 从 这 里 开 


本 站 共有 公告 于 条 与 RS 示 副 条 第 虽 页 共 国 页 明 “，4 呈 辐 肢 
国 胃 ”wm 咀 


s/h =a= i-| 


> ey 目 目 国 ?ax | 


图 9-40 ”所 有 新 闻 列 表 页 面 效果 
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该 页 面 的 编写 程序 部 分 如 下 所 示 : 
<?php 
$sql=mysql query("select count (*) as total from tb gonggao",$conn); 
$info=mysql fetch array($sql); 
$total=$info[totall]; 
if($total==0) 
{ 
echo "本 站 暂 无 公告 !"; 
1// 调 用 tb_gonggao 数 据 ， 如 果 没 有 则 显示 “本 站 暂 无 公告 !” 
else 
{ 
二 
<table width="530" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr bgcolor="#EEEEEE"> 
<td width="296" height="20"><div align="center"> 公 告 主题 
</div></td> 
<td width="136"><div alig 
<td width="68"><div align 
</tr> 
<?php 
$pagesize=20; 
if ($total<=$pagesize){ 
$pagecount=1; 
} 
if(($total%$pagesize)!=0){ 
$pagecount=intval ($total/$pagesize)+1; 


center"> 发 布 时 间 </div></td> 
center"> 查 看 内 容 </div></td> 


}elsel{ 
$pagecount=$total/$pagesize; 


} 

if(($_GET[page])==""){ 
Spage=17 

}jelset 
S$page=intval($_GET[Page]) 

} 


$sqll=mysql_ query ("select * from tb gonggao order by time 
desc limit ". (Spage-1)*Spagesize."vSpagesize ",$conn); 
while($infol=mysql_ fetch array($sql1)) 
上 


ES 
<Er> 
<td height="20"><div align="left">-<?php echo 
$infol [title];?></div></td> 
<td height="20"><div align="center"><?php echo 
$infol [time];?></div></td> 
<td height="20"><div align="center"><a 


href="gonggao.php?id=<?php echo $infol[id];?>"> 查 看 </a></div></td> 


二 
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</tr> 
<?php 
} 
人 
<tr> 
<td height="20" colspan="3"> &nbsp; 
<div align="right"> 本 站 共有 公告 ignbsp; 
<?php 
echo S$total; 
?> 
&nbsp; 条 &nbsp; 每 页 显示 &nbsp;<?php echo S$pagesize;?>&nbsp; 条 &nbsp; 第 
&nbsp;<?php echo $page;?>&nbsp; 页 / 共 &gnbsp;<?php echo S$pagecount; ?>g&nbsp; 
页 
<?php 
if($page>=2) 
{ 


> 

<a href="gonggaolist .php?page=1" title="” 首 页 "><font 
face="webdings"> 9 </font></a> <a href="gonggaolist.php?id=<?php echo 
$id;?>&amp;page=<?php echo S$page-1;?>" title=" 前 一 页 "><font 
face="webdings"> 7 </font></a> 

<?php 


} 
if($pagecount<=4){ 
for ($i=1;$i<=$pagecount;$i++){ 
?> 
<a href="gonggaolist.php?page=<?php echo $i;?>"><?php echo 
$i;?></a> 
<?php 
} 
}elsef 
for($i=1; $i<=4;$i++) { 
<a href="gonggaolist.php?page=<?php echo $i;?>"><?php echo 
$i;?></a> 
<?php }?> 
<a href="gonggaolist.php?page=<?php echo $page-1;?>" title=" 后 
一 页 "><font face="webdings"> 8 </font></a> <a 
href="gonggaolist .php?id=<?php echo $id;?>&amp;page=<?php echo 
$pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php ?> 
</div></td> 
</Er> 
</table> 
<?php 
} 
?></td> 
sr> 
</table> 


该 页 面 的 技术 难点 在 于 新 闻 标 题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 一 般 都 要 使 用 
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上 述 的 分 页 显示 功能 实现 按 页 显示 记录 。 
人 9.52 ) 显 示 详细 内 容 

具体 信息 量 显示 页 面 ， 通 常 包 括 所 显示 信息 的 标题 、 时 间 以 及 出 处 ， 制 作 的 具体 效果 
如 图 9-41 所 示 。 


示 cvampp\ntdocs\shop\gonggao php -DX 
FRED op php leftnenu php function php botton php 


幸福 从 这 里 开 
晶 彤 衣 的 见证 下 ! 
分 类 | 用 户 中 心 | 订单 查询 | 购 攀 车 


者 收 规 舟 . 湖 实 购 扫 计 


y Wy 目 目 国 ratzv 


图 941 详细 新 闻 页 面 
该 页 面 的 编写 程序 部 分 如 下 所 示 : 


<table width="530" border="0" align="center" cellpadding="0" 
cellspacing="1"> 
<?php 
$id=$_GET[id]; 
$sql=mysql_query ("select * from tb_gonggao where id="'".$id."'",S$conn); 


$info=mysql fetch array ($sql); 
include ("function.php"); 
2 

<tr> 

<td width="24" height="25" bgcolor="#FFFFFF"><div align="center"> 
</div></td> 

<td width="315" bgcolor="#FFFFFF"><div align="center"> 公 告 主题 <?php 
echo unhtml ($info[title]);?></div></td> 

<td width="66" bgcolor="#FFFFFF"><div align="center"> 发 布 时 间 : 
</div></td> 

<td width="120" bgcolor="#FFFFFF"><div align="left"><?php echo 
$info[time] ;?></div></td> 

</tr> 

<tr> 

<td height="125" bgcolor="#FFFFFF"><div align="center"></div></td> 

<td height="125" colspan="3" bgcolor="#FFFFFF"><div align="left"><?php 
echo unhtml ($info[content]);?></div></td> 

</tr> 

</table> 


通过 上 述 两 个 页 面 的 设计 ， 品 牌 新 闻 系 统 的 前 台 部 分 即 开发 完成 。 


a 


VySele 网 站 开 舌 全 程 实例 (第 2 版 ) 
(i 【 28 


有 1 9.6 ”产品 的 定购 功能 


购物 车 系统 主要 由 网 上 产品 定购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 的 
页 面 主要 有 产品 显示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 ， 主 要 包括 index.php、 用 于 显 
示 产 品 详细 信息 的 页 面 lookinfo.php，“ 最 新 婚纱 ”频道 页 面 shownewpr.php，“ 推 荐 品牌 ” 
频道 页 面 showtuijian.php，“ 热 门 品 牌 ” 频 道 页 面 showhot.php，“ 婚 纱 分 类 ”频道 页 面 
showfenlei.php， 产 品 搜索 结果 页 面 serchorder.php， 下 面 分 别 介 绍 除 了 首页 以 外 页 面 的 实现 
的 功能 。 


-98671 ) 产 品 介绍 页 面 


产品 介绍 页 面 lookinfo.php 是 用 来 显示 商品 细节 的 页 面 。 细节 页 面 要 能 显示 出 商品 所 有 
的 详细 信息 ， 包 括 商品 价格 、 商 品 产地 、 商 品 单位 、 商 品 图 片 ， 以 及 是 否 还 有 产品 放 入 购 
物 车 等 功能 ， 实 例 中 我 们 还 加 入 了 “商品 评价 ”功能 。 

由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-42 所 示 的 动态 页 面 。 在 页 面 中 ， 一 个 PHP 
代码 图 标 代 表 加 入 动态 命令 实现 该 功能 。 
曾 cvamepwudocaveopyookntophp 5 


RS op Pe mm he lof em phe betten pp 
下 RS 


@ ers 3 
人 


! 号 
CER -EE 


图 942 产品 介绍 页 面 
该 模块 的 程序 分 析 如 下 ， 其 中 购物 车 的 定购 代码 进行 了 加 粗 说 明 。 


<?PhP 

$sql=mysql_query("select * from tb_shangpin where 
id=".$_GET[id]."",$conn); 

$info=mysql_fetch object($sql); 

gt 

<tr> 

<td width="89" height="80" rowspan="4" align="center" valign="middle" 
bgcolor="#FFFFFF"><div align="center"> 

<?PhP 
if ($info->tupian==""){ 
echo " 暂 无 图 片 "; 

} 

else 

{ 


7 


国 
@ @ 下 


> 

<a href="<?php echo $info->tupian;?>" target=" blank"><img src="<?php 
echo $info->tupian;?>" alt=" 查看 大 图 " width="80" height="80" 
border="0"></a> 

<?php 

} 
i 

</div></td> 

<td width="92" height="20" align="left" bgcolor="#FFFFFF"><div 
align="center"> 商 品名 称 : </div></td> 

<td width="134"” bgcolor="#FFFFFF"><div align="left">é&nbsp;<?php echo 
$info->mingcheng;?></div></td> 

<td width="100" bgcolor="#FFFFFF"><div align="center"> 入 市 时 间 : 
</div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">ég&nbsp;<?php echo 
$info->addtime;?></div></td> 

</tr> 

<tr> 

<td height="20" align="]left" bgcolor="#FFFFFF"><div align="center"> 会 
员 价 : </div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">&nbsp;<?php echo 
$info->huiyuanjia;?></div></td> 

<td width="100" bgcolor="#FFFFFF"><div align="center"> 市 场 价 : 
</div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">é&nbsp;<?php echo 
$info->shichangjia;?></div></td> 

</tr> 

<tr> 

<td height="20" align="]left" bgcolor="#FFFFFF"><div align="center"> 等 
级 : </div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">&nbsp;<?php echo 
$info->dengji;?></div></td> 

<tdwidth="100" bgcolor="#FFFFFF"><div align="center"> 品 牌 : </div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">&nbsp;<?php echo 
$info->pinpai;?></div></td> 

</tr> 

<tr> 

<td height="20" align="]left" bgcolor="#FFFFFF"><div align="center"> 型 
号 ,， </div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">é&nbsp;<?php echo 
$info->xinghao;?></div></td> 

<td width="100" bgcolor="#FFFFFF"><div align="center"> 数 量 : </div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">é&nbsp;<?php echo 
$info->shuliang; ?></div></td> 

</Lr> 

> 

<td width="89" height="69" bgcolor="#FFFFFF"><div align="center"> 商 品 
简介 : </div></td> 

<td height="69" colspan="4" bgcolor="#FFFFFF" valign="top"><div 
align="]left"><br> 

&nbsp; gnbsp; &nbsp; gnbsp;<?php echo $info->jianjie;?></div></td> 

</Er> 

</table></td> 
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< Er 

</table> 

<table width="530" height="20" border="0" align="center" 
cellpadding="0" cellspacing="0"> 

<tr> 


<td><div align="right"><a href="addgouwuche .php?id=<?php echo 
$info->id;?>"> 放 入 购物 车 </a>gnbsp; &nbsp;</div></td>// 单 击 “ 放 入 购物 车 ”传递 产 
品 的 id 号 并 到 addgouwuche .php 去 结算 

/Er 

</table> 

<?php 

if($_SESSION[username]! 

{ 

2 

<form name="forml" method="post" action= 
$info->id;?>" onSubmit="return chkinput (this) 


nm ) 


"savepj .php?id=<?php echo 
> 


<table width="530" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
和 


<td height="25" bgcolor="#EEEEEE"><div align="center" style="color: 
#FFFFFF"> 
<div align="left">&nbsp; &nbsp;<span style="color: #000000"> 发 表 评 论 
</span></div> 
</div></td> 
Es 
< 
<td height="150" bgcolor="#999999"><table width="530" border="0" 
align="center" cellpadding="0" cellspacing="1"> 
<script language="javascript"> 
function chkinput (form) 


if(form.title.value=="") 
{ 
alert ("请 输入 评论 主题 !"); 
form.title.select(); 
return (false) 
} 
if(form.content.value=="") 
{ 
alert ("请 输入 评论 内 容 !")，; 
form.content.select (); 
return(false); 
} 
return (true); 
} 
</script> 
<tr> 
<td width="80" height="25" bgcolor="#FFFFFF"><div align="center"> 评 论 
主题 : </div></td> 
<td width="467" bgcolor="#FFFFFF"><div align="left"> 
<input type="text” name="title" size="30" class="inputcss" 
style="background-color:#e8f4ff 时 
onMouseOver="this.style.backgroundColor="'#ffffff"'" 
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onMouseOut="this.style.backgroundColor='#e8f4ff'"> 
</div></td> 
> 
<tr> 
<td height="125" bgcolor="#FFFFFF"><div align="center"> 评 论 内 容 : 
</div></td> 
<td height="125" bgcolor="#FFFFFF"><div align="left"> 
<textarea name="content™" cols="70" rows="10" class="inputcss" 
style="background-color:#e8f4ff 
onMouseOver="this.style.backgroundColor="'#£ffffff'" 
onMouseOut="this.style.backgroundColor='#e8f4ff'"></textarea> 
</div></td> 
</tr> 
</table></td> 
hE 
</table> 
<table width="530" height="25" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
E> 
<td><div align="center"> 
<input name="submit2" type="submit" class="buttoncss" value=" 发 表 "> 
&nbsp; Enbsp; Enbsp;<a href="showpl.php?id=<?php echo $ GET[id];?>"> 查 
看 该 商品 评论 </a></div></td> 
</tr> 
</table> 
</form> 
<?php 
} 


?> 


在 上 面 的 代码 中 ， 展 示 的 只 是 数据 的 查询 和 显示 功能 ， 核 心 功能 在 于 “发 表 评 论 ”， 
单 击 “ 发 表 ” 按 钮 后 将 传递 到 savepj.php 页 面 保 存 评 价 ， 其 页 面 的 代码 如 下 : 


<?PhP 

include ("conn/conn.php"); 

$title=$_POST[title]; 

$content=$_POST[content]; 

$spid=$_GET[id]; 

$time=date ("Y-m-j"); 

session start (); 

$sql=mysql_query ("select 所 from tb user where 
name='".$_SESSION[username] ."'", $conn); 

$info=mysql_ fetch array ($sql); 

$userid=$info[id]; 

mysql query("insert into tb pingjia (userid, spid,title,content,time) 
values ('$Suserid','$spid','$title','$content','$time’') ",$conn); 

echo "<script>alert(' 评 论 发 表 成 功 !') ;history.back();</script>"; 

2 


和 962 ) 最 新 婚纱 频道 


该 页 面 为 单 击 导航 条 中 的 “最 新 婚纱 ”链接 后 转 到 的 页 面 shownewpr.php， 主 要 是 显示 


= 949 


Wa 人 (第 2 版 ) 


aero 
完成 静态 页 面 的 设计 ， 该 页 面 完成 的 效果 如 图 9-43 所 示 。 


| 函 cvanppwudocesopwshownewprphp 
EY top php left_nnn ph borton pie 了 


翡 喷 


JADE WEN 


直 目 量 7ez3arvy 


图 9-43 ”最 新 婚纱 的 页 面 


代码 核心 部 分 如 下 : 


<table width="550" 
" cellspacing="0"> 


height="70" border="0" align="center" 


<?php 
$sql=mysql_ query ("select * from tb_shangpin order by addtime desc limit 
0,4",$conn); 
// 从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info=mysql_ fetch array($sql); 
if ($info==false){ 
echo "本 站 暂 无 最 新 产品 !"; 
} 
elsef{ 
dof{ 
了 全 
i 
<td width="89"rowspan="6"><div align="center"> 
<?PhP 
if($info[tupian]==""){ 
echo " 暂 无 图 片 !"; 
3 
else{ 


2% 
<a href="lookinfo.php?id=<?php echo S$info[id];?>"><img border="0" 


src="<?php echo $info[ltupian] ;?>" width="80" height="80"></a> 
<?php 
} 
有 区 
</div></td> 
<td width="93" height="20"><div align="center" style="color: #000000"> 


商品 名 称 : </div></td> 
<td colspan="5"><div align="left"><a href-"lookinfo.php?id=<?php echo 
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$info[id];?>"><?php echo $info[mingcheng];?></a></div></td> 

</tr> 

< 

<td width="93" height="20"><div align="center" style="color: #000000"> 
商品 品牌 : </div></td> 

<td width="101" height="20"><div align="left"><?php echo 
$info[pinpail];?></div></td> 

<td width="62"><div align="center" style="color: #000000"> 商 品 型 号 : 
</div></td> 


<td colspan="3"><div align="left"><?php echo 
$info[xinghao] ;?></div></td> 

</tr> 

< 


<td width="93" height="20"><div align="center" style="color: #000000"> 
商品 简介 : </div></td> 


<td height="20" colspan="5"><div align="left"><?php echo 
$info[jianjie];?></div></td> 

</tr> 

b>: 


<td height="20"><div align="center" style="color: #000000"> 上 市 日 期 : 
</div></td> 

<td height="20"><div align="left"><?php echo 
$info[addtime] ;?></div></td> 

<td height="20"><div align="center" style="color: #000000"> 剩 余数 量 : 
</div></td> 

<tad width="69" height="20"><div align="left"><?php echo 
$info[shuliang];?></div></td> 

<td width="63"><div align="center" style="color: #000000"> 商 品 等 级 : 
</div></td> 


<td width="73"><diV align="left"><?php echo 
$info[dengji];?></div></td> 

</tr> 

< 


<td height="20"><div align="center" style="color: #000000"> 商 场 价 : 
</div></td> 

<td height="20"><div align="left"><?php echo $info[shichangjia];?> 元 
</div></td> 

<td height="20"><div align="center" style="color: #000000"> 会 员 价 : 
</div></td> 

<td height="20"><div align="left"><?php echo $info[huiyuanjia];?> 元 
</div></td> 

<td height="20"><div align="center" style="color: #000000"> 折 扣 : 
</div></td> 


<td height="20"><div align="left"><?php echo 
(@ceil(($info[huiyuanjia]/$info[shichangjia]l)*100))."%";?></div></td> 

/E> 

<ir> 

<td height="20" colspan="6" width="461"><div 


align="center">&nbsp; gnbsp; &nbsp; gnbsp;<a href="addgouwuche.php?id=<?php 
echo $info[id];?>"><img src="images/bl.gif" width="50" height="15" 
border="0" style=" cursor:hand"></a></div></td> 

</Er> 

< 
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<td height="10" colspan="7" background="images/linel .gif"></td> 
</tr> 
<?php 
}while($info=mysql fetch array($sql)); 
} 
全 
</table> 


563) 推荐 品牌 频道 


该 页 面 为 单 击 导 航 条 中 的 “推荐 品牌 ”链接 后 转 到 的 页 面 showtuijian.php， 主 要 是 显 


示 数 据 库 中 推荐 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完成 的 效果 如 图 9-44 所 示 。 
二 cvampp\ntdocs\shop\showtuijian php 0 光 


TRE op, php left menu php botton. php 


有 推荐 产品 天 件 条 9 示 半 件 第 时 页 共 唆 页 盟 w* 妈 妈 眶 
四 


VW 呈 天 目 目 国 exsev 


图 9-44 ”推荐 品牌 的 页 面 


推荐 品牌 的 功能 和 最 新 婚纱 频道 功能 基本 上 一 样 的 ， 不 同 的 地 方 就 是 在 于 推荐 时 从 数 
据 库 查询 的 代码 不 一 样 ， 主 要 代码 不 同 部 分 如 下 所 示 。 


<?PhP 
$sql=mysql_query("select count (*) as total from tb_shangpin where 

tuijian=1 ",$conn); 

// 从 tb_shangpin 数 据 表 中 查询 出 tuijian=1 的 商品 
$info=mysql fetch array($sql); 
$total=$info[total]; 
if($total==0) 

. 
echo "本 站 暂 无 推荐 产品 !"; 
} 
else 
! 


Fi 
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和 564 ) 热 门 品牌 频道 


该 页 面 为 单 击 导 航 条 中 的 “热门 品牌 ”链接 后 转 到 的 页 面 showhot.php， 主 要 是 显示 数 
据 库 中 热门 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完 成 的 效果 如 图 9-45 所 示 。 


二 cwampp\ntdocs\shop\showhot php 
EY top php left_nenu php botton php 了 


翡 琅 类 你 


JADE WEN 


> Wy 目 目 时 Tezsserv 


图 9-45 热门 品牌 的 页 面 
热门 品牌 的 功能 代码 主要 核心 不 同 部 分 如 下 所 示 。 


<?php 
$sql=mysql query ("select * from tb shangpin order by cishu desc 
limit 0,10",$conn); 
// 从 tb_shangpin 数 据 表 中 查询 出 10 条 的 热门 品牌 
$info=mysql fetch array($sql); 
if ($info==false) 


{ 
echo "本 站 暂 无 热门 产品 !"; 
} 

else 

{ 


do 
{ 


2 


-和 965 ) 婚 纱 分 类 频道 


该 页 面 为 单 击 导航 条 中 的 “热门 品牌 ”链接 后 转 到 的 页 面 showfenlei.jphp， 按 商品 的 分 
类 显示 不 同 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完 成 的 效果 如 图 9-46 所 示 。 
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图 9-46 分 类 的 页 面 
分 类 的 功能 代码 主要 不 同 部 分 如 下 所 示 。 
<?php 
if($_GET[id]=="") 
{ 
$sql=mysql query ("select * from tb type order by id desc limit 
Qi" Sconn})s 
// 从 tb_type 数 据 表 中 查询 出 所 有 的 商品 分 类 
$info=mysql_ fetch array($sql); 
$id=$info[id]; 
} 
else 
{ 
$id=$_GET[id]; 
} 
$sqll=mysql query("select * from tb _ type where id=".$id."",$conn); 
$infol=mysql fetch array($sqll); 


$sql=mysql_query ("select count (*) as total from tb_shangpin where 
typeid='".$id."' order by addtime desc ",$conn); 
$info=mysql_ fetch array($sql); 
Stotal=$info [total]7 
if($total==0) 
echo "<div align='center'> 本 站 暂 无 该 类 产品 !</div>"; 
} 
else 
8 


”9.6.6 ) 产 品 搜索 结果 
6) 


一 般 的 大 型 网 站 都 存在 搜索 功能 ， 在 首页 中 要 设置 商品 搜索 功能 。 通 过 输入 搜索 的 商 
品 ， 单 击 搜索 按钮 后 ， 要 打开 的 页 面 就 是 这 个 商品 搜索 结果 页 面 serchorder.php。 
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由 上 面 的 功能 分 析出 发 ， 设 计 好 的 商品 搜索 结果 页 面 如 图 9-47 所 示 。 


-Ox 


| 函 cvemppwadoesehopsechordecphp 
EY on php top pip loft pone pop bottm pe 


到 
[和 


目 目 国 ?0 1 


图 9-47 产品 搜索 结果 页 面 
相关 的 程序 代码 分 析 如 下 : 


<?php 
$jdcz=$_POST[jdcz]; 
$name=$_POST[name]; 
$mh=$_POST[mh]; 
$dx=$_POST[dx]; 

ee 


} 
elseif ($dx=="-1")1{ 
$dx="<"; 
} 
else{ 
Sdx="="; 
} 
$jg=intval($_POST[jg]); 
$1b=$_POST[1b]; 
if ($jdcz!=""){ 
$sql=mysql query("select * from tb shangpin where mingcheng like 
1g%" .$name."%'! order by addtime desc",$conn);// 按 分 类 名 称 查询 tb_shangpin 数 据 


表 


} 
else 
{ 
if ($mh=="1"){ 
$sql=mysql_query("select * from tb_shangpin where huiyuanjia $dx".$jg." 
and typeid='".$]1lb."' and mingcheng like '%".$name."%'",S$conn); 
}// 按 会 员 价 查询 tb_shangpin 数 据 表 
else{ 
$sql=mysql_query("select * from tb_shangpin where huiyuanjia $dx".$jg." 
and typeid='".$1lb."' and mingcheng = '".S$name."'",S$conn); 
} 
} 
$info=mysql_ fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 本 站 暂 无 类 似 产 
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品 ! ');history.go(-1);</script>"; 

} 

else{ 

> 

<table width="530" border="0" align="center" cellpadding="0" 
cellspacing="1" bgcolor="#CCCCCC"> 

<tr bgcolor="#FOFOFO"> 

<td width="92" height="25"><div align="center" style="color: #990000"> 
名 称 </div></td> 

<td width="83"><div align="center" style="color: #990000"> 品牌 
</div></td> 

<td width="62"><div align="center" style="color: #990000"> 市 场 价 
</div></td> 

<td width="62"><div align="center" style="color: #990000"> 会 员 价 
</div></td> 

<td width="161"><div align="center" style="color: #990000"> 上 市 时 间 
</div></td> 

<td width="48"><div align="center" style="color: #FFFFFF"><span 
class="stylel"></span></div></td> 

<td width="42"><div align="center" style="color: #990000"> 操作 
</div></td> 


EC 

<?php 

dof{ 

?> 

<tr bgcolor="#FFFFFF"> 

<td height="25"><div align="center"><?php echo 
$info[mingcheng] ;?></div></td> 

<td height="25"><div align="center"><?php echo 
$info[pinpail];?></div></td> 

<td height="25"><div align="center"><?php echo 
$info[shichangjia];?></div></td> 

<td height="25"><div align="center"><?php echo 
$info[huiyuanjia];?></div></td> 

<td height="25"><div align="center"><?php echo 


$info[addtime] ;?></div></td> 
<td height="25"><div align="center"><a href="lookinfo.php?id=<?php 
echo $info[id];?>"> 查 看 </a></div></td> 
<td height="25"><div align="center"><a href="addgouwuche .php?id=<?php 
echo $info[id];?>"> 购 物 </a></div></td> 
</tr> 
<?PhP 
}while($info=mysql fetch array($sql)); 
} 
2 
</table></td> 
</tr> 
</table> 


到 这 里 ， 就 完成 了 商品 相关 动态 页 面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 定购 的 
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栈 9.7 ”网 站 的 购物 车 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 与 网 上 定购 、 结 算 功 能 ， 在 网 站 建设 中 这 块 的 知 
识 统 称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 进行 产品 结算 ， 通 过 这 个 功能 ， 用 户 
在 选择 了 自己 喜欢 的 产品 后 可 以 通过 网 站 确认 所 需要 的 产品 ， 输 入 联系 办 法 ， 提 交 后 写 入 
数据 库 ， 方 便 网 站 管理 者 进行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 


-5377 ) 放 入 购物 车 


addgouwuche.php 页 面 在 前 面 的 代码 中 经 常 应 用 到 ， 就 是 单 击 “ 购 买 ” 图 标 按钮 后 ， 需 
要 调用 的 页 面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完 全 是 PHP 代 码 ， 如 图 9-48 
所 示 。 


| 画 cwamppwtdocaemepwddoouwuchephp 3 


一 
Ptyalart(" 请 先 登录 后 购物 | ] ;history. back() ;</script>” 


i]); 
(selact # Fron th_shantpin where id .$id.”", Scomn) 
ch_array ($91); 

je=0) 


rt 该 商品 已 经 入 完 |") ;history.back() ;4/script>” 


[zcdaceliet]. id. 做 
[guatit] "10" 
) 


图 9-48 addgouwuche.php 页 面 的 设计 


代码 分 析 如 下 : 


<?php 
session start(); 
include ("conn/conn.php"); 
if($_SESSION[username]==""){ 
echo "<script>alert (' 请 先 登 录 后 购物 !');history.back() ;</script>"; 
exit; 
}// 判 断 是 否 已 经 登录 
$id=strval ($_GET[id]); 
$sql=mysql_query("select * fromtb shangpin where id='".$id."'",S$conn); 
$info=mysql fetch array ($sql); 
if ($info[shuliang] <=0){ 
echo "<script>alert (' 该 商品 已 经 售 完 !') ;history.back();</script>"; 
exit; 
}// 判 断 是 否 还 有 产品 
$array=explode ("@",$_SESSION[producelist]); 
for ($i=0; $i<count ($array) -1;$i++){ 
if($array[$i]==$id){ 
echo "<script>alert(' 该 商品 已 经 在 您 的 购物 车 中 !') ;history.back(); 
</script>";// 判 断 是 否 重复 购买 


exit; 
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一 


$_SESSION [Producelist]=$_SESSION [producelist] .$id."@"; 
$_SESSION[quatity]=$_ SESSION[quatity] ."1l@"; 


header ("location:gouwuche.php");// 实 现 统计 累加 的 功能 并 进行 转向 
?> 


他 二 个 ， 


session 在 PHP 编 程 技 术 中 ， 占 有 非常 重要 份量 的 函数 。 由 于 网 页 是 一 种 无 状态 的 连接 程序 ， 因 
此 无 法 得 知 用 户 的 浏览 状态 。 必 须 通过 session 变 量 记录 用 户 的 有 关 信 息 ， 以 供用 户 再 次 以 此 身 
份 ， 对 服务 器 提供 要 求 时 作 确 认 。 


< 9.7.2 ) 清 空 购物 车 


在 购物 车 定购 过 程 中 通过 单 击 “删除 ”和 “清空 购物 车 ”文字 链接 ， 能 够 调用 
removegwc.php 页 面 ,通过 里 面 的 命令 清空 购物 车 中 的 数据 统计 , 设计 的 PHP 命 令 , 如 图 9-49 


二 cwampp\htdocs\shopvemovegwc php 本 
a EY :ptp "| 


session_start(); 
$id=$_GET[1d]; 
$arraysp=explode("@",$_SESSION[producelist]); 
$arraysl=explode("@",$_SESSION[quatity]); 
- for($1=0;$i<count ($arraysp);$i++){ 
人 if($arraysp[$1]==$1d){ 
$arraysp[$i 
$arraysl[$i 
} 


i 


} 
$_SESSION[producelist]=implode("@", $arraysp); 
$_SESSION[quatity]=implode("@", $arraysl); 
header ("location:gouwuche.php"); 


图 9-49 removegwc.php 页 面 
清除 订单 的 代码 如 下 : 


<?php 
session start(); 
$id=$_GET[id]; 
$arraysp=explode("@",$_ SESSION[producelist]); 
$arraysl=explode ("@",$_ SESSION[quatity]); 
for($i=0;$i<count ($arraysp) ;$i++){ 
if($arraysp[$i]==$id){ 
$arraysp[$i]=""; 
$arraysl[$i]=""; 

} 

站 
$_SESSION[producelist]=implode("@", $arraysp); 
$_SESSION[quatity]=implode ("@", $arrays1); 
header ("location:gouwuche.php"); 
es 


通过 上 面 的 命令 可 以 清空 购物 车 里 的 订单 ， 并 返回 gouwuche.php 本 


哄 


进行 定购 。 
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-973 ) 收 款 人 信息 


用 户 登 录 后 选择 商品 放 入 购物 车 ， 单 击 首页 上 的 “去 收银 台 ” 文 字 链 接 ， 则 打开 订单 
用 户 信 息 确 认 页 面 gouwusuan.php， 在 该 页 面 中 设置 收 货 人 的 详细 信息 ， 设 置 的 结果 如 图 
9-50 所 示 。 


cv gm -ox 
i he。 Lett_neeu Hg hvttmpty 了 


幸福 从 这 里 开始 ... 
日 粽 衣 的 见证 下 ! 


量 015 3 4%4+ 


图 9-50” 收 款 人 信息 页 面 


974 ) 生 成 订单 功能 


单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd.php 页 面 ， 该 页 面 的 功能 是 : 把 订单 写 入 数 
据 库 后 返回 gouwusuan.php 页 面 ， 具 体 代 码 如 下 : 


<?php 
session start(); 
include ("conn/conn.php"); 
$sql=mysql_query ("select 责 from tb user where 
name='".$_SESSION[username] ."'", $conn); 
$info=mysql fetch array ($sql); 
$dingdanhao=date ("YmjHis") .$info[id]; 
$spc=$_SESSION[producelist]; 
$slc= $_SESSION [quatity]; 
$shouhuoren=$_POST [name2]; 
$sex=$_POST[sex]; 
$dizhi=$_POST[dz]; 
$youbian=$_POST [yb]; 
$tel=$ POST[tel]; 
$email=$_POST [email]; 
$shff=$_ POST[shff]; 
$zZfff=$ POST[ZzZfff]; 
if (trim($_POST[ly])=="")1{ 
$leaveword=""; 
} 
else{ 
$leaveword=$ POST[ly]; 
} 
$xiadanren=$ SESSION[username]; 
$time=date("Y-m-j H:i:s"); 


- 359 - 


We ee 得 实例 (第 2 版 ) 


$zt=" 未 作 任 何 处 理 "; 

$total=$_SESSION [totall]; 

mysql _query ("insert into tb dingdan(dingdanhao, spc,slc, shouhuoren, 
sex,dizhi,youbian,tel,email,shff,zfff,leaveword,time,xiadanren,zt,total) 
values ('$dingdanhao','$spc', '$slc','$shouhuoren', '$sex','$dizhi', 
ee er 下 这 下 
nren yr "SZt rr Stotal ”Soonny? 

header ("location:gouwusuan.php?dingdanhao=$dingdanhao"); 

> 


-975 ) 订 单 查询 功能 


用 户 在 购物 的 时 候 , 还 需要 知道 自己 在 最 近 一 共 购 买 了 多 少 商品 , 单 击 导 航 条 上 的 “ 订 
单 查 询 ” 命 令 ， 打 开 查 询 输 入 的 页 面 finddd.php， ee sini in ge 
者 是 下 订单 人 姓名 ， 都 可 以 查 到 订单 的 处 理 情况 页 面 ， 方 便 与 网 站 管理 者 的 沟通 。 订 单 查 
询 功 能 和 首页 上 的 商品 搜索 功能 设计 方法 是 一 样 的 ， sade 
的 连接 ， 设 置 查询 输入 文本 域 ， 建 立 查询 命令 ,具体 的 设计 分 析 类 似 前 面 的 搜索 功能 模块 
设计 ， 完 成 的 效果 如 图 9-51 所 示 。 


| 冯 cvampowdocssnopvinedd pno EE 
RSD 00.phe Left neru php bntto .pi 


D> [ET FTE 


图 9-51 订单 查询 页 面 


整个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 我 们 都 已 经 介绍 完了 ， 还 有 其 他 一 些小 
功能 页 面 这 里 就 不 做 介绍 了 ， 如 果 用 户 在 使 用 时 可 以 根据 自己 的 需求 对 网 站 进行 一 定 的 完 
善 和 更 改 ， 达 到 自己 的 使 用 要 求 。 
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全 程 实例 八 : 暮 娟 电子 商城 后 人 台 


翡翠 电子 商城 前 台 主 要 实现 了 网 站 针对 会 员 的 所 有 功能 ,包括 了 会 员 注册 、 购 物 车 以 
及 留言 功能 的 功能 开发 。 但 一 个 完善 的 网 上 购物 系统 并 不 只 提供 给 用 户 注册 ， 还 要 给 网 站 
所 有 者 一 个 功能 齐全 的 后 台 管 理 功 能 。 网 站 所 有 者 登录 后 台 管 理 即 可 进行 发 布 新 闻 公 告 、 
会 员 注册 信息 的 管理 、 回 复 留 言 、 商 品 维护 ， 以 及 进行 订单 的 处 理 等 。 本 章 主 要 介绍 翡 以 
电子 商城 后 台 的 一 些 功 能 开发 。 


电子 商城 系统 后 台 的 规划 
商品 管理 功能 的 开发 
用 户 管理 功能 的 开发 
订单 管理 功能 的 开发 
信息 管理 功能 的 开发 


人心 
) 会 


;6@pHP 网 站 开 性 全 程 实例 (第 ?2 版) 
ye 人 


10.1 电子 商城 系统 后 台 规 划 


电子 商城 的 后 台 管理 系统 是 整个 网 站 建设 的 难点 ， 它 包括 了 几乎 所 有 的 常用 PHP 处 理 
技术 ， 也 相当 于 一 个 独立 运行 的 系统 程序 。 实 例 的 后 台 主 要 要 实现 “商品 管理 ”、“ 用 户 
管理 ”、“ 订 单 管理 ”以 及 “信息 管理 ”四 大 功能 模块 ， 在 进行 具体 的 功能 开发 之 前 ， 和 
网 站 前 台 的 制作 方法 一 样 首先 要 进行 一 个 后 台 的 需求 整体 规划 。 


1011) 后 台 页 面 的 设计 


本 实例 将 所 有 制作 的 后 台 管 理 页 面 放 置 在 admin 文 件 夹 下 面 ， 和 单独 设计 一 个 网 站 一 
样 需要 建立 一 些 常 用 的 文件 夹 如 用 于 连接 数据 库 的 文件 夹 conn、 用 于 放置 网 页 样式 表 的 文 
件 夹 css、 放 置 图 片 的 文件 夹 images， 以 及 用 于 放置 上 传 的 产品 图 片 文件 夹 upimages， 设 计 
完成 的 整体 文件 夹 及 文件 如 图 10-1 所 示 。 


ee 加 
登 品 小 wxampp » hdoce » chop ， admin ss 加 | P| 
六 3 妨 绚 日” 可 大 V) 工具 (nm)。 帮 动 Cr 

衣 只 ” 。 包公 到 eh ” 。 共享 ” 。 则 好 。 天 建 广 怕 本 "| 四 @ 


图 10-1 网 站 后 台 文 件 结构 
该 网 站 后 台 总 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 上 说 并 不 比 前 台 的 开发 简单 。 对 需 
要 设计 的 页 面 功能 分 析 如 下 : 


addgonggao.php: 增加 新 闻 公 告 的 页 面 
addgoods.php: 增加 商品 信息 的 页 面 
addleibie.php: 增加 商品 类 别 的 页 面 
admingonggao.php: 增加 商品 公告 的 页 面 
changeadmin.php: 管理 员 信 息 变 改 页 面 
changegoods.php: 商品 信息 变更 页 面 
changeleaveword.php: 会 员 留 言 变更 页 面 
chkadmin.php: 管理 员 登 录 验 证 页 面 
conn/conn.php: 数据 库 连 接 文件 页 面 
default.php: 后 台 登 录 后 的 首页 
deleted.php: 删除 订单 的 页 面 
deletefxhw.php: 删除 商品 信息 页 面 
deletegonggao.php: 删除 公告 信息 页 面 
deletelb.php: 删除 商品 大 类 页 面 
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deleteleaveword.php: 删除 用 户 留 言 页 面 
deletepingjia.php: 删除 商品 评论 页 面 
deleteuser.php: 删除 用 户 信息 页 面 
dongjieuser.php: 冻结 用 户 处 理 页 面 
editgonggao.php: 编辑 公告 内 容 页 面 
editgoods.php: 编辑 商品 信息 页 面 
editleaveword.php: 编辑 用 户 留 言 页 面 
editpinglun.php: 编辑 用 户 评 论 页 面 
edituser.php: 编辑 用 户 信息 页 面 
finddd.php: 订单 查询 页 面 

function.php: 调用 的 常用 函数 

index.php: 后 台 用 户 登 录 

leftphp: 展开 式 树 状 导航 条 

lookdd.php: 查看 订单 页 面 
lookleaveword.php: 查看 用 户 留 言 页 面 
lookpinglun.php: 查看 用 户 评 论 页 面 
lookuserinfo.php: 查看 用 户 信息 页 面 
orddd.php: 执行 订单 页 面 
saveaddleibie.php: 保存 新 增 商 品 大 类 页 面 
savechangeadmin.php: 保存 用 户 信息 变更 页 面 
Savechangegoods.php: 保存 经 修改 商品 信息 
saveeditgonggao.php: 保存 经 修改 公告 内 容 
savenewgonggao.php: 保存 新 增 公 告 信 息 
savenewgoods.php: 保存 新 增 公告 信息 
saveorder.php: 保存 执行 订单 页 面 
showdd.php: 打印 订单 的 功能 页 面 
showleibie.php: 商品 大 类 显示 页 面 
top.php: 后 台 管 理 的 顶部 文件 


< 多 10.1.2 ) 后 台 管理 登录 页 面 


后 台 的 功能 开发 和 网 站 的 前 台 的 功能 展示 开发 并 不 大 一 样 ， 前 台 除 了 功能 的 需求 之 
外 , 还 需要 讲究 更 多 的 网 页 布局 即 网 站 的 美工 设计 , 后 台 的 开发 主要 重视 功能 的 需求 开发 ， 
而 网 页 美工 可 以 放 到 其 次 。 本 小 节 介绍 一 下 网 站 后 台 从 登录 到 可 实现 的 管理 具体 有 哪些 流 
程 ， 以 方便 读者 更 容易 了 解 后 面 小 节 的 内 容 介绍 。 

对 于 网 站 拥有 者 需要 登录 后 台 进 行 管理 网 上 购物 系统 ， 由 于 涉及 到 很 多 商业 机 密 ， 所 
以 需要 设计 登录 用 户 确认 页 面 ， 通 过 输入 惟一 的 用 户 名 和 密码 来 登录 后 台 进 行 管理 。 本 网 


上 购物 系统 为 了 方便 使 月 


， 只 需要 在 首页 用 户 系统 中 直接 输入 “用 户 名 ”admin 和 “密码 ” 


admin， 登 录 的 地 址 为 : http://127.0.0.1/shop/admin/login.php， 如 图 10-2 所 示 。 
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图 10-2 后 台 管 理 登 录 页 面 
单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 图 10-3 所 示 。 


图 10-3 后 台 管 理 主 界面 
单 击 左边 树 状 的 管理 菜单 中 的 “商品 管理 ”菜单 项 ， 可 以 看 到 它 包 含 了 增加 商品 、 修 
改 商 品 、 类 别管 理 、 添 加 类 别 4 个 功能 选项 ， 通 过 这 4 个 功能 主要 实现 商品 的 添加 、 修 改 管 
理 ， 如 图 10-4 所 示 的 增加 商品 页 面 。 


全 育 委 加 1 700 eel 


图 10-4 “增加 商品 ”页 面 


如 果 想 实现 对 用 户 的 管理 ,可 以 单 击 “ 用 户 管理 ”菜单 项 , 里 面包 括 了 会 员 管 理 、“ 留 
言 管 理 以 及 更 改 管理 员 3 个 菜单 选项 。 在 这 3 个 功能 中 ， 后 台 管 理 者 不 但 可 以 实现 对 注册 会 
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*@" 


员 的 删除 ， 还 可 以 实现 相应 留言 的 删除 管理 ， 对 于 后 台 登 录 的 admin 身 份 也 可 以 进行 变更 ， 
如 图 10-5 所 示 的 后 台 管理 者 变更 。 
Se [http/127.0.0. Ushop/admin/derauit php 一 一 -Es 5 


Fra Er Frere 
i EE EE EE 
. ER ER 


图 10-5 ”后台 管理 者 变更 页 面 


订单 管理 是 购物 系统 后 台 管理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”展开 菜单 ， 可 以 看 到 包 
括 了 编辑 订单 和 查询 订单 两 个 功能 项 。 其 中 编辑 订单 就 是 实现 前 台 会 员 下 订单 后 与 管理 者 
的 一 个 交互 ， 管 理 者 需要 及 时 处 理 订单 ， 并 进行 发 货 方 可 以 实现 购物 交易 的 环节 ， 编 辑 订 
单 的 页 面 如 图 10-6 所 示 。 


匠 350s 全 中 了 1 
. 


10-6 编辑 订单 页 面 


单 击 “ 信 息 管理 ”展开 菜单 可 以 看 到 包括 了 管理 公告 、 发 布 公告 和 管理 评价 3 个 功能 ， 
通过 这 3 个 功能 能 够 实现 整个 网 站 的 即时 新 闻 发 布 、 公 告 修 改 以 及 商品 评论 的 编辑 修改 功 
能 ， 如 图 10-7 所 示 。 
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图 10-7 管理 公告 页 面 
从 上 述 的 后 台 管理 者 从 登录 到 各 功能 的 管理 页 面 来 看 ， 本 实例 的 后 台 管 理 功能 非常 的 
流畅 ， 能 够 为 后 台 管理 提供 非常 便利 的 网 站 管理 后 台 ， 这 也 是 需要 网 站 设计 者 与 管理 者 沟 
通 到 位 ， 问 清 需求 后 方 可 以 规划 出 实用 的 网 站 后 台 。 


< 10.1.3 ) 设 计 后 台 管理 
- 般 后 台 管 理 者 在 进行 后 台 管 理 时 都 是 需要 进行 身份 验证 ， 实 例 用 于 登录 的 页 面 如 图 
10-8 所 示 ， 在 单 击 “登录 ”按钮 后 ， 判 断后 台 登 录 管理 身份 的 确认 动态 文件 chkadmin.php。 


DE 


曾 cvamppwdocsshopwdminognPhp 四 
| ES font css 


图 10-8 ”后台 管理 登录 静态 效果 
该 页 面 制作 也 比较 简单 ， 主 要 的 功能 代码 如 下 : 


<script language="javascript"> 
function chkinput (form){ 
if (form.name.value==""){ 
alert ("请 输入 用 户 名 !"); 


form.name.select (); 
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return (false); 
} 
if (form.pwd.value==""){ 
alert ("请 输入 用 户 密码 !"); 
form.pwd.select (); 
return (false); 
} 
return(true); 
}// 单 击 登 录 按钮 进行 表单 的 验证 
</script> 
<form name="forml™" method="post" action="chkadmin .php" 


onSubmit="return chkinput (this)"> 
// 通 过 验证 后 转 到 chkadmin.PhP 进 行 判断 


chkadmin.php 是 判断 管理 者 身份 是 否 正 确 的 页 面 ， 使 用 PHP 写 的 程序 如 下 : 


<?php 
class chkinput{ 
var $name; 
var $pwd; 
function chkinput ($x,$y) 
{ 
$this->name=$x; 
$this->pwd=$y; 
1 
function checkinput () 
{ 
include ("conn/conn.php"); 
$sql=mysql_query ("select 和 from tb _admin where 
name='".$this->name."'", $conn);// 从 数据 表 tb_admin 调 出 数据 
$info=mysql_ fetch array ($sql); 
if ($info==false) 
{ 
echo "<script language='javascript'>alert(' 不 存在 此 管理 员 ! 
') ;history.back();</script>"; 
exit; 
}// 如 果 不 存在 则 显示 为 “不 存在 此 管理 员 ” 
else 
{ 
if ($info[pwd]==$this->pwd){ 
header ("location:default.php"); 
}// 如 果 正 确 则 登录 default .php 页 面 
else 


{ 
echo "<script language='javascript'>alert(' 密码 输入 错误 ! 


yrhistory.back();</script>"; 
exit; 


} 


S$obj=new chkinput (trim($ POST[name]),md5 (trim($ POST[pwd]))); 
S$obj->checkinput (); 
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-10.1.4 ) 设 计 树 状 菜单 
后 台 管 理 的 导航 菜单 是 一 个 树 状 的 展开 式 菜单 ， 分 为 二 级 菜单 ， 在 单 击 一 级 菜单 时 可 
以 实现 二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver 中 设计 的 样式 如 图 10-9 所 示 。 


二 cyamppntdocs\shopadminVeRtphp -Ox 
TE cent cc 


日 目 哇 S77xd3v | 


图 10-9 树 状 导航 菜单 
而 实现 动态 的 展开 和 合并 是 使 用 JavaScript 实 现 的 ， 核 心 的 代码 如 下 : 


<script language="javascript"> 
function openspgl(){ 
if (document.all .spgl.style.display=="none"){ 
document .all .spgl.style.display=""; 
document.all.dl.src="images/point3.gif"; 
} 
else{ 
document.all.spgl.style.display="none"; 
document.all.dl.src="images/pointl.gif"; 
3 
} 
function openyhgl() { 
if(document.all .yhgl .style.display=="none"){ 
document.all .yhgl .style.display=""; 
document .all.d2.src="images/point3.gif"; 
下 
else{ 
document.all.yhgl.style.display="none"; 
document .all.d2.src="images/point]l .gif"; 
} 
} 
function openddgl(){ 
if(document.all .ddgl .style.display=="none"){ 
document .all .ddgl .style.display=""; 
document.all.d3.src="images/point3.gif"; 
} 
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elsef{ 


document.all.ddgl.style.display="none"; 
document.all.d3.src="images/point]l.gif"; 
} 
} 
function opengggl (){ 
if(document.all.gggl .style.display=="none"){ 
document.all .gggl .style.display=""; 


document.all.d4.src="images/point3.gif"; 
} 
elsef{ 


document.all.gggl.style.display="none"; 
document .al1.d4.src="images/Point1.gif"7 
} 
} 

</script> 


上 述 的 代码 经 常 应 用 于 网 站 的 动态 菜单 设计 ， 读 者 可 以 将 其 应 用 于 其 他 的 网 站 ， 甚 至 
是 网 站 的 前 台 菜单 。 


2 10.2 ”商品 管理 功能 


由 需求 出 发 ， 商 品 管理 包括 了 增加 商品 、 修 改 商品 、 类 别管 理 和 添加 类 别 4 个 功能 主 
页 面 ， 本 小 节 就 介绍 这 儿 个 商品 管理 功能 页 面 程序 的 实现 方法 。 


< T0211) 新 增 商 品 


在 前 台所 有 展示 的 产品 都 是 要 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 字段 要 与 数据 库 
中 保存 商品 的 设计 字段 一 一 对 应 ， 实 例 设计 的 增加 商品 addgoods.php 静 态 页 面 效 果 如 图 
10-10 所 示 。 


支 cvamppdocsvihop cminaddgoodsphp = 
MED Eont, css conn php 


KI Woy EE 


自嘲 ?x 4 


图 10-10 ”增加 商品 的 页 面 效果 
动态 的 程序 核心 代码 如 下 : 
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<script language="javascript"> 
function chkinput (form) 
if(form.mingcheng.value=="") 
{ 
alert ("请 输入 商品 名 称 !"); 
form.mingcheng.select (); 
return(false); 
} 
if(form.huiyuanjia.value=="") 
{ 
alert ("请 输入 商品 会 员 价 !") ; 
form.huiyuanjia.select(); 
return(false); 
} 
if(form.shichangjia .value=: 
{ 
alert ("请 输入 商品 市 场 价 !") ; 
form.shichangjia.select(); 
return(false); 
} 
if(form.dengji .value=="") 
{ 
alert ("请 输入 商品 等 级 !"); 
form.dengji.select (); 
return(false); 
} 
if(form.pinpai .value=="") 
| 
alert ("请 输入 商品 品牌 !"); 
form.pinpai.select (); 
return(false); 
} 
if(form.xinghao.value=="") 
{ 
alert ("请 输入 商品 型 号 !"); 
form.xinghao.select (); 
return(false); 
} 
if(form.shuliang.value=="" 
Ui 
alert ("请 输入 商品 数量 !"); 
form.shuliang.select(); 
return(false); 
} 
if(form.jianjie.value=="") 
由 
alert ("请 输入 商品 简介 !"); 
form.jianjie.select (); 
return(false); 
} 


return (true); 


') 
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</script>// 进 行 表 单 验证 
<form name="forml" enctype="multipart/form-data" method="post" 
action="savenewgoods.php"” onSubmit="return chkinput(this)">// 验 证 后 提交 
savenewgoods .php 页 面 进行 处 理 


savenewgoods.php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 码 如 下 : 


<?php 
include ("conn/conn.php"); 
if(is numeric($ POST[shichangjial])==false 11 
is numeric($ POST[huiyuanjial])==false) 
{ 
echo "<script>alert (' 价 格 只 能 为 数字 ! ');history.back();</script>"; 
exit; 
} 
if(is numeric($ POST[shuliang])==false) 
{ 
echo "<script>alert (' 数 量 只 能 为 数字 ! ');history.back();</script>"; 
exit; 
} 
$mingcheng=$_POST[mingcheng]; 
$nian=$_POST[nian]; 
$yue=$_ POST[yuel]; 
$ri=$_POST[ri]; 
$shichangjia=$_POST[shichangjial]; 
$huiyuanjia=$_POST[huiyuanjial]; 
$typeid=$_POST[typeid]; 
$dengji=$_POST[dengjil]; 
$xinghao=$_POST [xinghao]; 
$pinpai=$_POST[pinpail]; 
$tuijian=$_ POST[tuijian]; 
$shuliang=$_POST[shuliang]; 
$upfile=$_ POST[upfile]; 
if(ceil(($huiyuanjia/$shichangjia)*100)<=80) 
{ 


$tejia=1; 
} 
else 
{ 
$tejia=0; 
} 
function getname ($exname){ 
$dir = "upimages/";// 列 出 产品 图 片 的 上 传 目录 
$i=1; 
if(!is dir($dir)){ 
mkdir ($dir,0777); 
} 
while(true) { 
if(!is filel($dir.$i.".".S$exname)){ 
$name=$i.".".S$exname; 
break; 
} 
下 


return S$dir.s$name; 
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$exname=strtolower (Substr($_FILES[I'upfile']['name']，(strrPos ($_FILES 
["upfile"']il'name"],".")+1))): 
Suploadfile = getname ($exname); 
move _ uploaded file($ FILES['upfile']['tmp name'], S$uploadfile); 
if (trim($_ FILES['upfile']['name']!="")) 
$uploadfile="admin/".$uploadfile; 
} 
else 
{ 
$uploadfile=""; 
} 
$jianjie=$ POST[jianjie]; 
$addtime=$nian."-".$yue."—".$ri; 
mysql_query("insert into tb_ shangpin (mingcheng,jianjie,addtime,dengji, 
xinghao, tupian,typeid,shichangjia,huiyuanjia,pinpai,tuijian,shuliang,ci 
shu)values('$mingcheng', '$jianjie','$addtime','$dengji','$xinghao','s$up 
loadfile','S$typeid','$shichangjia', '$huiyuanjia','$pinpai','$tuijian',’' 
$shuliang', '0')",S$conn); 
echo "<script>alert(' 商 品 " .$mingcheng ." 添 加 成 功 !'); 
window.location.href='addgoods.php';</script>"; 


?>// 上 传 成 功 转向 addgoods .php 页 面 
上 述 PHP 的 程序 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 


-10232 ) 修 改 商品 


在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “ 修 改 商品 ”功能 来 
进行 商品 信息 的 调整 ， 在 后 台中 单 击 “修改 商品 ”打开 的 是 editgoods.php 页 面 。 


加 使 用 Dreamweaver 制 作 的 静态 页 面 效果 如 图 10-11 所 示 。 


夯 campp\hedccewhopvwdminwdrgoodsphp E 
SUSY tont css eomn phe 时 


E> wy ma 
图 10-11 修改 商品 静态 页 面 效果 
加 在 该 页 面 中 选中 “ 复 选 ” 复 选 框 ， 单 击 “ 删 除 选择 ”按钮 可 以 实现 链接 到 
deletefkhw.php 页 面 进行 删除 操作 。 从 数据 库 中 删除 商品 信息 ， 使 用 的 代码 如 下 : 


<?PhP 
include ("conn/conn.php"); 
while (list($name,$value)=each($_ POST)) 
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{ 
$sql=mysql query("select tupian from tb shangpin where id='".$value. 
"'",$conn); 
$info=mysql_ fetch array($sql); 
if($info[tupian] !="") 
{ 

@unlink (substr ($info[tupian],6, (strlen($info[tupian])-6))); 
$sqll=mysql query("select * from tb dingdan ",$conn); 
while($infol=mysql fetch array($sql1)) 

{ $idil=$infol [id]; 

$array=explode ("@",$infol[spc]); 

for ($i=0;$i<count ($array); $i++) { 
if($array [$i]==$value) 


mysql_query("delete from tb dingdan where id='".$idl."'",$conn); 
} 
} 
} 
mysql_query("delete from tb shangpin where id='".$value. 
mT Sconn) 7 
mysql_query ("delete from tb pingjia where spid='".$value."'",$conn); 
} 
header (" Location:editgoods .php"); 


SC 
贺 通过 单 击 “ 更 改 ”文字 链接 能 打开 changegoods.php 页 面 进行 商品 的 信息 变更 页 面 ， 
该 页 面 设计 的 样式 和 添加 产品 时 的 样式 是 一 模 一 样 的 ， 如 图 10-12 所 示 。 


芭 cvampp\ntdocs\shopwadmin\changegoods php = 
ERED Eont css eonn php 了 


ET 


三 目 目 国 7zesv | 


图 10-12 修改 商品 字段 采集 页 面 


贺 在 编辑 商品 信息 之 后 ， 单 击 “ 更 改 ”按钮 提交 表单 到 savechangegoods.php 页 面 进 
行 数据 库 的 更 新 操作 ， 核 心 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 


-373 - 


e@_ 网 站 开发 全 程 实例 〈 第 2 版 ) 
SS @De 


<?php 

include ("conn/conn.php"); 
$mingcheng=$ POST[mingcheng]; 
$nian=$_POST[nian]; 
$yue=$_POST[yue]; 

$ri=$_ POST[ri]; 

$shichangjia=$ POST[shichangjial; 
$huiyuanjia=$ POST [huiyuanjial]; 
$typeid=$ POST[typeid]; 
$dengji=$_ POST[dengjil]; 
$xinghao=$ POST[xinghao]; 
$pinpai=$ POST[pinpail]; 
$tuijian=$ POST[tuijian]; 
$shuliang=$_POST[shuliang]; 
//$upfile=$_ POST[upfilel]; 


if(ceil(($huiyuanjia/$shichangjia)*100)<=80) 
{ 
$tejia=1; 
} 
else 
{ 
$tejia=0; 
} 
if ($upfile!="") 
{ 
$sql=mysql_query("select * from tb_ shangpin where id=".$_ GET[id]. 
"", $conn); 
$info=mysql fetch array ($sql); 
@unlink(substr ($info[tupian],6, (strlen($infol[tupian])-6))); 
} 


function getname ($exname){ 
$dir = "upimages/"; 
$i=1; 
if(!is dir($dir))t{ 
mkdir ($dir,0777); 


while(true) 1{ 
if(!is file($dir.$i.".".$exname)){ 
$name=$i.".".S$exname; 
break; 

} 

$++3 


return S$dir.$name; 
} 
$exname=strtolower (substr($ FILES['upfile']['name'], (strrpos($_FILES 


['upfile']['name'],'.')+1)))s? 
$uploadfile = getname ($exname); 


a 


. 
全 @ 时 


move_upPloaded_ file($_FILES ['upfile'] ['tmP_name']，Suploadfile): 

$uploadfile="admin/".$uploadfile; 

$jianjie=$ POST[jianjie]; 

$addtime=$nian."-".$yue."-".$ri; 

mysql_ query ("update tb shangpin set 
mingcheng=' $mingcheng',jianjie="'$jianjie',addtime='$addtime', dengji="'$d 
engji',xinghao='$xinghao',tupian='$uploadfile',typeid='$typeid',shichan 
gjia='$shichangjia',huiyuanjia='$huiyuanjia',pinpai='$pinpai',tuijian=" 
$tuijian', shuliang='$shuliang' where id=".$ GET[id]."",$conn); 

echo "<script>alert(' 商 品 " .$mingcheng ." 修 改 成 功 !');history.back();; 
</aoript>"y 

2 


更 新 数据 库 主要 应 用 到 了 update 这 个 数据 库 更 新 的 命令 。 
人 10.2.3 ) 类 别管 理 


商品 的 类 别提 供 了 删除 功能 ， 选 中 “操作 ” 复 选 框 ， 再 单 击 “ 删 除 选 项 ”按钮 即 可 将 
类 别 从 数据 库 中 删除 ， 该 功能 首页 为 showleibie.php。 

使 用 Dreamweaver 设 计 的 该 页 面 的 静态 效果 如 图 10-13 所 示 。 该 页 面 主要 实现 从 类 别 的 
数据 表 中 查询 出 相应 的 数据 绑 定 到 该 页 面 。 


和 
示 cvwampp\htdocs\shopvadmin\showleibie php = x 
| NRE font. ess conn php 于 | 


Es 入 


目 目 呢 so x 192~ 
图 10-13 类 别管 理 主页 面 


选中 相应 的 类 别 复 选 框 ， 单 击 “ 删 除 选项 ”按钮 提交 表单 到 deletelb.php 动 态 页 面 进行 
删除 ， 在 删除 时 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 通 过 商品 的 这 同时 删除 tb_type 和 
tb_shangpin 即 可 实现 ， 实 现 删除 类 别 的 代码 如 下 : 


<?PhP 
include ("conn/conn.php"); 
while(1ist(S$namevS$value)=each($_POST) )1{ 
mysql_query ("delete from tb_type where id='".$value."'",$conn);// 删 
除 类 别 
mysql_query ("delete from tb_shangpin where id='".$value."'",$conn);// 
删除 类 别 下 的 商品 
header ("location:showleibie.php"); 
// 删 除 成 功 转向 showleibie .php 页 面 


二 
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< 10.2.4 ) 添 加 类 别 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 台 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开 
发 中 经 党 有 一 级 分 类 、 二 级 分 类 甚至 三 级 分 类 ， 这 些 还 涉及 到 菜单 的 二 级 联动 问题 。 本 实 
例 只 建立 了 一 级 分 类 ， 管 理 者 可 以 在 后 台 直 接 添加 一 级 的 分 类 ， 添 加 类 别 功能 的 主页 面 是 
addleibie.php。 

使 用 Dreamweaver 设计 addleibie.php 页 面 的 静态 效果 ， 如 图 10-14 所 示 。 


,| Cvampp\htdocs\shop\admin\addleibie php 
QT font. css 


目 国 包 444 x 147v 


图 10-14 设计 的 增加 类 别 主 页 效果 


在 单 击 “ 增 加 ”按钮 的 时 候 要 进行 表单 验证 ， 并 提交 到 saveaddleibie.php 页 面 进行 插入 
数据 库 的 操作 ， 该 页 面 的 代码 如 下 : 
$leibie=$_POST[leibie]; 
include ("conn/conn.php"); 
$sql=mysql_query("select * from tb type where 
typename='".$leibie."'", $conn); 
$info=mysql_ fetch array ($sql); 
if ($info!=false){ 
echo"<script>alert (' 该 类 别 已 经 存 
在 !') ;window.location.href='addleibie.php';</script>"; 
exit; 
} 
// 判 断 类 别 是 否 存在 
mysql_query("insert into tb type (typename) values ('$leibie')",$conn); 
echo"<script>alert (' 新 类 别 添加 成 
功 !') ;window.location.href='addleibie.php';</script>"; 
pw 
// 添 加 成 功 指向 addleibie .php 


在 编写 的 时 候 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 要 加 入 一 个 判断 。 
10.3 用户 管 理 功 能 
用 户 管理 功能 与 前 台 的 用 户 注册 功能 是 互相 呼应 的 ， 对 于 购物 网 站 来 说 ， 一 个 完善 


的 
用 户 管理 系统 一 定 要 有 一 个 功能 比较 强大 的 用 户 后 台 管 理 ， 实 例 里 面 制作 了 会 员 管理 、 留 
言 管理 和 更 改 管理 员 3 个 菜单 项 。 本 小 节 就 介绍 这 几 个 小 功能 的 实现 方法 。 
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< 加 10.3.1 ) 会 员 管理 


结 ” 的 操作 ， 保 留 会 员 的 信息 ， 但 禁止 其 在 前 台 进 行 购物 及 发 言 。 会 员 
edituser.php， 人 制作 的 详细 步骤 如 下 : 


贺 使 用 Dreamweaver 设 计 的 页 面 如 图 10-15 所 示 。 


示 cvampp\tdocsshopvdminvedituserphp -Ox 
NRE font css com php a 


KIS boy 目 目 国 skzzo | 
图 10-15 会 员 管 理 主页 edituser.php 


加 选中 “删除 ” 复 选 框 ， 单 击 “ 删 除 选项 ”按钮 能 够 提交 表单 到 deleteuser php 动 态 
页 面 ， 实 现 会 员 数 据 删除 的 操作 ， 该 页 面 的 程序 如 下 : 


<?php 
include ("conn/conn.php"); 
while (list ($name, $value)=each ($_POST)) 


{ 
mysql query("delete from tb user where id=".S$value."", $conn); 


mysql_query("delete from tb pingjia where userid=".$value.""); 

mysql_query("delete from tb leaveword where userid=".S$value."",$conn); 
} 

header ("location:edituser.php"); 

2 


语 导 和合 ， 


在 删除 会 员 的 时 候 同 样 要 注意 删除 数据 库 中 tb_user、tb_pingjia 和 tb_leaveword 3 个 数据 表 中 所 有 
关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管理 主页 面 。 


在 单 击 “ 查 看 详细 ”链接 后 ， 打 开 的 是 对 用 户 “ 冻 结 ” 和 “解冻 ”的 页 面 
lookuserinfo.php， 设 计 的 页 面 如 图 10-16 所 示 。 
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图 10-16 用户 信息 页 面 ookuserinfo.php 
在 程序 的 编写 时 实现 “冻结 ”和 “解冻 ”其 实 非 常 的 简单 ， 只 须 用 赋值 为 0 或 者 1 来 区 
分 是 否 冻结 ， 在 查询 会 员 信息 的 时 候 按 查 询 是 0 或 者 是 1 来 给 会 员 权 限 。 代 码 如 下 : 


<?php 
$sql=mysql query ("select * from tb user where id=".$id."",S$conn); 
$info=mysql_ fetch array($sql); 
if($info [dongjie]==0) 
{ 
echo "冻结 该 用 户 "; 
} 
else 
{ 
echo "解除 冻结 "; 
} 


Ea 


< 10.3.2 ) 留 言 管理 


会 员 当 在 购物 时 遇 到 问题 可 以 直接 通过 留言 功能 和 管理 者 进行 沟通 ， 在 后 台 管 理 者 要 
及 时 浏览 会 员 的 留言 并 进行 相应 的 处 理 ， 对 于 一 些 没 用 的 留言 可 以 进行 直接 的 删除 操作 。 
用 于 留言 管理 的 主页 面 是 lookleaveword.php 页 面 。 

制作 的 lookleaveword.php 页 面 效 果 如 图 10-17 所 示 。 


Xl 


二 cvampp\ntdocs\shopadmin\ookieaveword. php -Ox 
EE 2 
加 


> voy [EL 


图 10-17 留言 处 理 主页 面 lookleaveword.php 
该 页 面 也 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ， 选 中 “删除 ” 复 选 框 ， 
单 击 “删除 选项 ”按钮 提交 表单 信息 至 deleteleaveword.php 页 面 进行 删除 数据 的 操作 ， 实 现 
删除 的 代码 如 下 : 
<?php 
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include ("conn/conn.php"); 
while (list ($name, $value)=each ($_ POST)) 
{ 
mysql_ query("delete fromtb leaveword where id='".$value."'",$conn); 
} 
header ("location:lookleaveword.php"); 
?>// 删 除 成 功 返 回 lookleaveword.php 


1033 ) 更 改 管理 员 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 名 和 密码 都 是 admin， 在 提交 给 网 站 管理 者 时 ， 
为 了 安全 起 见 ， 管 理 者 要 能 够 实现 后 台 管理 者 的 用 户 名 和 密码 的 修改 ， 实 现 该 功能 的 主页 
面 是 changeadmin.php。 

制作 的 更 改 管理 员 主 页 changeadmin.php 的 效果 如 图 10-18 所 示 。 


i -ox 
EY ont ess 了 


日 日 时 Tixiwv 


图 10-18 ”网 站 管理 者 后 人 台 修 改 主页 面 
在 输入 新 旧 管 理 员 的 用 户 名 和 密码 ， 在 单 击 “ 更 改 ” 按 钮 可 以 提交 表单 进行 验证 并 提 
交 到 savechangeadmin.php 进 行 数据 更 新 的 操作 ， 实 现 的 代码 如 下 : 
<?php 
$n0=$_POST[n0]; 
$n1=$_POST [n1]; 
$p0=md5($_POST[pO0]); 
$pl=trim($_ POSTI[p1]); 
include ("conn/conn.php"); 
$sql=mysql_query ("select * from tb admin where name='".$n0. 
"in, $conn); 
$info=mysql_ fetch array($sql); 
if($info==false) 
{ 
echo "<script>alert(' 不 存在 此 用 户 !');history.back();</script>"; 
exit; 
} 
else 
| 
if ($info[pwd]==$p0) 
{ 
En 
{ 
mysql_ query ("update tb admin set name='" .Sn1."'where 
id=".$info[id]." ",$conn); 


} 
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$pl=md5 ($p1); 
mysql_ query("update tb admin set pwd='".$pl."' where 
id=".$info[id] ."",$conn); 
} 
1 
else 
Li 
echo "<script>alert (' 原 密码 输入 错误 !') ;history.back();</script>"; 
exit; 
1 
} 
echo "<script>alert(' 更 改 成 功 !') ;history.back();</script>"; 
> 


该 程序 首先 对 管理 员 的 用 户 名 进行 验证 , 判断 正确 后 才 进 行 更 新 数据 , 并 显示 更 新 成 功 。 
10.4 ”订单 管理 功能 


订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 者 而 言 一 定 要 及 时 登录 后 台 对 订单 进 
行 管理 并 及 时 发 货 。 实 现在 登录 后 台 时 把 订单 管理 的 功能 放 到 了 默认 打开 的 页 面 ， 主 要 包 
括 了 “编辑 订单 ”和 “查询 订单 ”两 个 小 功能 ， 下 面 分 别 进行 介绍 。 
E1047) 编辑 订单 

所 谓 的 编辑 订单 是 指 管理 者 在 登录 后 台 后 ， 对 会 员 提 交 的 订单 进行 “已 收 款 ”、“ 已 
发 货 ” 和 “已 收 货 ” 验 证 ， 同 进 要 及 时 打印 出 网 上 订单 提交 给 公司 进行 发 货 处 理 。 编 辑 订 
单 的 主页 是 lookdd.php。 


加 设计 的 lookdd.php 页 面 的 效果 如 图 10-19 所 示 。 该 页 面 也 只 是 简单 的 订单 信息 功能 ， 
只 要 从 数据 库 中 本 泡 订 中 坟 本 于 而 好 可 ， 


加 
OR 


记 body 目 目 国语 zz6v 
图 10-19 查看 订单 页 面 lookdd.php 
贺 设计 的 第 二 步 就 是 实现 单 击 “ 查 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd.php 
页 面 并 能 进行 打印 ， 效 果 如 图 10-20 所 示 。 
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国 cwampp\htdocsshopvadmin\showdd php = 
| GE font. ess comn php ba 
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图 10-20 订单 详细 内 容 
showdd.php 页 面 中 调用 函数 实现 打印 的 功能 ， 有 具体 的 代码 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 商 品 订单 </title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
<style type="text/css"> 
ed ey 
@media print{ 
div{display:none} 
} 
.style3 {color: #990000} 
--> 
</style> 
</head> 
<?php 
include ("conn/conn.php"); 
$id=$_GET[id]; 
$sql=mysql_ query ("select * from tb dingdan where id='".$id. 


:$conn); 


$info=mysql_ fetch array($sql); 
$spc=$info[spc]; 
$slc=$info[slc]; 
$arraysp=explode ("@", $spc); 
$arraysl=explode ("@",$slc); 


?> 

<body topmargin="0" leftmargin="0" bottommargin="0"> 

<p>&nbsp;</p> 

<table width="600" border="0" align="center" cellpadding="0" 


cellspacing="0"> 


<tr align="center" bgcolor="#FFCF60"> 
<td height="20" colspan="2" bgcolor="#0099FF"> 商 品 订单 </td> 
去 /> 
<tr> 
<td width="448" height="20"> 订 单 号 : <?php echo $infol[dingdanhao]; 
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?></td> 


<td width="152"><div align="right"> 
<script> 
function prn(){ 
document .all .WebBrowserl] .ExecWB (7,1); 
} 
</script> 
// 实 现 打印 预览 的 功能 
<object ID="'WebBrowserl' WIDTH=0 HEIGHT=0 CLASSID='CLSID: 
8856F961-340A-11D0-A96B-00C04FD705A2'></object> 
<input type="button"” value=" 打 印 预览 " class="buttoncss" onClick= 
"prn()">gnbsp; 
<input type="button" value=" 打 印 " class="buttoncss" onClick= 
"window.print()"></div></td> 
// 实 现 打 印 的 功能 
</tr> 
二 七 工 之 
<td height="20" colspan="2"> 商 品 列表 (如 下 ) : </td> 
EX 
</table> 
<table width="500" height="60" border="0" align="center" cellpadding 
="0" cellspacing="0"> 
<tr> 
<td bgcolor="#666666"><table width="500" border="0" align="center" 
cellpadding="0" cellspacing="1"> 
<tr bgcolor="#0099FF"> 
<td width="153" height="20"> 商 品名 称 </td> 
<td width="80"> 市 场 价 </td> 
<td width="80"> 会 员 价 </td> 
<td width="80"> 数 量 </td> 
<td width="101"> 小 计 </td> 
KEF> 
<?php 
$total=0; 
for ($i=0; $i<count ($arraysp) -1;$i++) { 
if($arraysp[$i]!=""){ 
$sqll=mysql_ query("select * from tb shangpin where id='". 
$arraysp [$i] "$conn);? 
$infol=mysql fetch array($sql1); 
$total=$total+=$arraysl [$i]*$infol [huiyuanjial]; 
3 六 
<tr bgcolor="#FFFFFF"> 
<td height="20"><?php echo $infol [mingcheng];?></td> 
<td height="20"><?php echo $infol[shichangjial];?></td> 
<td height="20"><?php echo $infol[huiyuanjia];?></td> 
<td height="20"><?php echo S$arraysl[$i];?></td> 
<td height="20"><?php echo $arraysl[$i] 
*$infol[huiyuanjia] ;?></td> 
</tr> 
<?php 
} 
} 
> 


<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="5"> 
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总 计 费 用 :<?php echo S$total;?> 
</td> 
</tr> 
</table></td> 
中 由 这 过 
</table> 
<table width="460" border="0" align="center" cellpadding=" 
cellspacing="0"> 
<tr> 
<td width="81" height="20"> 下 单 人 : </td> 
<td colspan="3"><?php echo $info[xiadanren];?></td> 
/Er 
Er 
<td height="20"> 收 货 人 : </td> 
<td height="20" colspan="3"><?php echo $info[shouhuoren];?></td> 
Er 
和 
<td height="20"> 收 货 人 地 址 : </td> 
<td height="20" colspan="3"><?php echo $info[dizhi];?></td> 
<Atr> 
2 
<td height="20"> 邮 &nbsp;&nbsp; 编 : </td> 
<td width="145" height="20"><?php echo $info[youbian];?></td> 
<td width="66"> 电 &nbsp; &nbsp; 话 : </td> 
<td width="158"><?php echo $info[tel];?></td> 
</tr> 
<tr> 
<td height="20">E-mail:</td> 
<td height="20"><?php echo $info[email];?></td> 
<td height="20">gnbsp;</td> 
<td height="20">gnbsp;</td> 
</tr> 
< 
<td height="20"> 送 货 方式 : </td> 
<td height="20"><?php echo $info[shff];?></td> 
<td height="20"> 支 付 方式 : </td> 
<td height="20"><?php echo $info[zfff];?></td> 
< Er 
<tr> 
<td height="20" colspan="4"><span class="inputcssnull"> 汇 款 时 注 明 您 
的 订单 号 ! 汇款 后 请 及 时 联系 我 们 ! </span></td> 


</Er> 
<E> 
<td height="20">gnbsp;</td> 
<td height="20"><div align="center"><input type="button" 


onClick="window.close()"” value=" 关 闭 窗口 "class="buttoncss"></div></td> 
<td height="20"> 创 建 时 间 : </td> 
<td height="20"><?php echo $info[ltime];?></td> 
/E> 
</table> 
</body> 
</html> 


园 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd.php 页 面 ， 进 行 订 
单 的 处 理 ， 上 面包 括 了 “已 收 款 ”、“ 已 发 货 ”、“ 已 收 货 ”3 个 复 选项 ， 对 其 进行 相应 
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的 处 理 ， 如 图 10-21 所 示 。 


曾 cvenppmaoswhopwdnmodesapm -Ex 
RE tnt. ess comn php 0 


] 


| Wa 目 目 国 soztzv 


图 10-21 标记 订单 orderdd.php 


国 单 击 “修改 ”按钮 ， 即 提交 表 到 saveorder.php 页 面 进行 修改 数据 的 保存 ， 具 体 的 
代码 如 下 : 

<?php 

$ysk=$_POST[ysk] ."&nbsp;"; 

$yfh=$_POST[yfh]."g&nbsp;"; 

$ysh=$_POST[ysh]."g&nbsp;"; 


Sb 
if($ysk!="gnbsp;")1{ 
$zt.=$ysk; 


} 
if ($yfh!="gnbsp;"){ 
$zt.=$yfh; 
} 
if($ysh!="gnbsp;"){ 
$zt.=$ysh; 
时 
if(($ysk=="&nbsp;") && ($yfh=="&nbsp;") && ($ysh=="&nbsp;"))t{ 
echo "<script>alert (' 请 选择 处 理 状态 !') ;history.back() ;</script>"; 
exit; 
} 
include ("conn/conn.php"); 
$sql3=mysql_ query("select * from tb dingdan where id='".$ GET[id]. 
mw, Sconn)} 
$info3=mysql_ fetch array ($sql3); 
if (trim($info3[zt])==" 未 作 任 何 处 理 ") { 
$sql=mysql_query ("select * from tb dingdan where id='".$ GET[id]. 
nmin, $conn); 
$info=mysql fetch array($sql); 
$array=explode ("@", $info[spc]); 
$arraysl=explode ("@", $info[slc]); 


for ($i=0;$i<count ($array); $i++){ 


= 


$id=$array[$i]; 
$num=$arraysl [$i]; 
mysql query("update tb shangpin set cishu=cishut'".$num."' 
shuliang=shuliang-'".$num."' where id='".$id."'",$conn); 
} 
} 
mysql_ query ("update tb dingdan set zt='".$zt."'where id= 
mp on 
header ("location:lookdd.php"); 
Fe 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开 发 完成 。 
T1042 查询 订单 


在 网 站 运营 一 段 时 间 后 , 网 上 的 订单 会 越 来 越 多 , 也 经 常会 遇 到 会 员 查询 订单 的 事情 ， 
网 站 管理 者 同样 也 需要 一 个 订单 的 后 台 查 询 功 能 ， 才 能 方便 地 找到 相应 的 订单 。 实 例 查询 
和 显示 的 结果 是 在 同一 个 页 面 ， 即 finddd.php 。 

制作 的 finddd.php 页 面 效 果 如 图 10-22 所 示 。 


一 一 
示 campp\htdocs\shop\admin\finddd php | 
和 了 font. ess comn php 


< bey [5 目 目 呢 592 x 280v 


图 10-22 ”查询 订单 finddd.php 


核心 程序 如 下 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 订 单 查询 </title> 


<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 


<?php 
include ("conn/conn.php"); 

2 

<body topmargin="0" leftmargin="0" bottommargin="0"> 

<p>g&nbsp;</p> 

<table width="550" border="0" align="center" cellpadding="0" 
cellspacing="0"> 

<tr> 
<td height="20" bgcolor="#0099FF"><div align="center" style= 
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"color: #FFFFFF"> 订 单 查询 </div></td> 
人 
二 
<td height="50" bgcolor="#555555"><table 
height="50" border="0" align="center" cellpadding="0" cellspacing= 
<Ez> 
<td bgcolor="#FFFFFF"> 
<table width="550" height="50" border 
"0" cellspacing="0"> 
<script language="javascript"> 
function chkinput3 (form) 


"align="center" cellpadding= 


{ 
if((form.username .value=="") && (form.ddh.value=="")) 
{ 
alert ("请 输入 下 订单 人 或 订单 号 "); 
form.username.select(); 
return (false); 
} 


return (true); 


} 
</script> 
<form name="form3" method="post" action="finddd.php" 
onSubmit="return chkinput3( this)"> 
i 
<td height="25"><div align="center"> 下 订单 人 姓名 :<input 
type="text" name="username" class="inputcss" size="25" > 
订单 号 :<input type="text" name="ddh" size="25" 
class="inputcss" ></div></td> 
</tr> 
<tr> 
<td height="25"> 
<div align="center"> 
<input type="hidden" value="show find" name="show find"> 
<input name="button" type="submit" class= 
"buttoncss" id="button" value=" 查 找 "> 
</div></td> 
</tr> 
</form> 
</table></td> 
</Er> 
</table></td> 
</Er> 
</table> 
<table width="550" height="20" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
-EE 
<td>gnbsp;</td> 
</tr> 
</table> 
<?php 
if($ POST[show find] !=""){ 
$username=trim($ POST[username]); 
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外 
@ @ 于 


S$ddh=trim($_POST [ddh]) 
if($username==""){ 
$sql=mysql query("select * from tb dingdan where dingdanhao= 
nw ddh monn 
} 
elseif ($ddh=="") { 
$sql=mysql_ query ("select * from tb dingdan where xiadanren= 
'".$username.™"™'",S$conn); 
} 
elsel{ 
$sql=mysql query("select * from tb dingdan where xiadanren= 
'".$Susername."'and dingdanhao='".$ddh."'", $conn); 
} 
$info=mysql_ fetch array($sql); 
if($info==false){ 
echo "<div algin='center'> 对 不 起 ,没有 查找 到 该 订单 !</div>"; 
} 
elsel 
?> 
<table width="550" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td height="20" bgcolor="#0099FF"><div align="center" 
style="color: #FFFFFF"> 查 询 结 果 </div></td> 
</tr> 
ee 
<td height="50" bgcolor="#555555"><table width="550" 
height="50" border="0" align="center" cellpadding="0" cellspacing="1"> 
<tr> 
<td width="77" height="25" bgcolor="#FFFFFF"><div 
align="center"> 订 单 号 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 下 单 


用 户 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 订 货 
人 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 金 额 
总 计 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 付 款 
方式 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 收 款 
方式 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 订 单 
状态 </div></td> 
</tr> 
<?php 
dof 
个 
GE 


<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[dingdanhao] ;?></div></td> 

<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[xiadanren];?></div></td> 

<td height="25" bgcolor="#FFFFFF"><div align= 
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"center"><?php echo $info[shouhuoren];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[total];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[zfff];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[shff];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align= 
"center"><?php echo $info[zt];?></div></td> 
< 
<?php 
}while ($info=mysql fetch array ($sql)); 
Bs 
</table></td> 
</tr> 
</table> 
<?php 
} 
} 
2 
</body> 
</html> 


四 10.5 信息 管理 功能 


信息 管理 功能 就 是 指 在 网 站 后 台 能 够 实现 新 闻 、 用 户 的 商品 评价 等 一 些 相 关 的 管理 操 
作 ， 实 例 制作 了 管理 公告 、 发 布 公告 和 管理 评价 3 个 功能 ， 通 过 这 3 个 功能 能 够 实现 整个 网 
站 的 即时 公告 发 布 、 公 告 修改 以 及 商品 评论 的 编辑 修改 功能 。 
GD 10.5.1 ) 管 理 公告 
管理 公告 功能 是 指 在 后 台 对 发 布 的 公告 可 以 进行 修改 和 删除 的 操作 ， 实 例 管理 公告 的 
主页 为 admingonggao.php。 
加 制作 好 的 admingonggao.php 页 面 效 果 如 图 10-23 所 示 。 


a = 
REY tont ers com sho 了 
图 


Co "Ee 


图 10-23 管理 公告 admingonggao.php 
贺 选中 “选择 ” 复 选 框 ， 单 击 “ 删 除 所 选 ” 按 钮 将 表单 提交 到 deletegonggao.php 进 
行 删除 公告 的 操作 ， 代 码 如 下 : 


<?PhP 
include ("conn/conn.php"); 
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while(list(Sname,Svalue)=each ($_POST) ) 
{ 
mysql query("delete from tb gonggao where id='".$value."'",S$conn); 
} 
header ("location:admingonggao.php"); 
> 


园 单 击 “ 修 改 ” 文 字 链 接 ， 可 以 打开 editgonggao.php 页 面 进行 公告 的 编辑 操作 ， 该 
页 面 如 图 10-24 所 示 。 


着 cvomppedocshopwdminvediaorooeophp 于 
to 了 | 


图 10-24 修改 公告 editgonggao.php 


园 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ” 按 钮 可 以 提交 表单 到 
saveeditgonggao.php 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 


<?php 
$title=$_ POST[title]; 
$content=$_POST[content]; 
include ("conn/conn.php"); 


mysql_query ("update tb_gonggao set title='$title',content='$content' 
where id='".$_ POST[id]."'",S$conn); 


echo "<script>alert (' 公 告 修改 成 功 !');history.back();</script>"; 
?> 


1052D) 发 布 公 千 


用 于 添加 新 的 公告 页 面 是 addgonggao.php， 实 现 的 方法 就 是 采集 公告 的 字段 进行 数据 
的 插入 操作 即 可 以 完成 ， 本 小 节 就 介绍 新 添加 公告 的 具体 方法 。 


制作 采集 公告 的 addgonggao.php 页 面 如 图 10-25 所 示 。 


证 cvenppwadecwhepeanreaaaoneeophnp -ox 
EE 要 
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图 10-25 addgonggao.php 页 面 的 效果 
贺 录入 完 主题 和 内 容 ， 单 击 “ 添 加 ”按钮 可 以 提交 表单 进行 验证 ， 并 提交 到 
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Savenewgonggao.php 页 面 进行 新 闻 公 告 的 保存 操作 ， 实 现 的 代码 如 下 : 
<?php 
include ("conn/conn.php"); 
$title=$ POST[title]; 
$content=$_ POST[content]; 
$time=date("Y-m-j"); 


mysql query("insert into tb gonggao (title,content,time) values 
('$title', '$content', "$time')", Sconn) > 


echo "<script>alert (' 公 告 添加 成 功 !') ;history.back();</script>"; 
ya 


< 105.3 ) 管 理 评价 


后 台 的 最 后 一 个 功能 是 管理 评价 功能 ， 通 过 管理 可 以 将 商品 的 一 些 负面 信息 进行 删 
除 ， 管 理 评价 功能 的 页 面 是 editpinglun.php， 制 作 的 方法 如 下 : 
加 制作 的 editpinglun.php 页 面 效果 如 图 10-26 所 示 。 


曾 cyarppweecnsopeanrvednpnghnphp 
OES cnt ess cam pip 


LE 
图 10-26 编辑 用 户 评价 editpinglun.php 


贺 通过 单 击 “ 查 看 ”文字 链接 能 打开 Windows 窗 口 显 示 评价 的 详细 内 容 ， 实 现 的 代 


码 如 下 : 
<?php 
include ("conn/conn.php"); 
$sql=mysql_query ("select count(*) as total from tb pingjia "， 
$conn); 


$info=mysql_fetch array($sql); 
$total=$info[total]; 
if($total==0) 
{ 
echo "本 站 暂 无 用 户 发 表 评 论 !"; 
} 
else 
{ 


?> 

<script language="javascript"> 

function openpj (id) 

{ 
window.open("lookpinglun.php?id="+id,"newframe","width=500,height=30 


0,top=100,left=200,menubar=no,toolbar=no, location=no, scrollbar=no, statu 
s=no"); 
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选中 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选 项 ”按钮 将 表单 提交 至 删除 评价 的 页 面 
deletepingjia.php， 该 页 面 的 代码 如 下 : 


本 章 系统 地 讲解 了 翡翠 电子 商城 的 后 台 管理 开发 办 法 ， 一 般 的 电子 商城 的 常用 功能 也 
无 非 就 是 这 些 ， 有 些 比 较 复杂 的 结算 系统 如 积分 系统 ， 病 代 结 算 系统 等 都 是 在 使 用 PHP 的 
运算 函数 基础 上 使 用 客户 提供 的 结算 运算 公式 去 实现 的 。 读 者 可 以 触 类 旁 通 ， 举 一 反 三 ， 
在 掌握 本 系统 开发 方法 的 基础 上 做 更 多 的 需求 开发 ， 真 正成 为 PHP 高 级 程序 员 。 
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